.post-author{display:flex;align-items:center;gap:10px}.author-avatar,.default-avatar,.anonymous-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.default-avatar{background-color:#007bff;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.anonymous-avatar{background-color:#6c757d;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.post-options{display:flex;align-items:center;margin-bottom:10px}.anonymous-option{display:flex;align-items:center;gap:5px;cursor:pointer;-webkit-user-select:none;user-select:none}.anonymous-option input[type=checkbox]{cursor:pointer}#root{width:100dvw;display:flex;justify-content:center}.auth-links{display:flex;flex-direction:column;gap:10px;margin-top:20px}.auth-links button{background:none;border:none;color:#2196f3;cursor:pointer;font-size:.9em;padding:5px}.auth-links button:hover{text-decoration:underline}.skip-button{color:#666!important;font-size:.85em!important}.skip-button:hover{color:#333!important}.auth-container{background-color:var(--bg-secondary);color:var(--text-primary)}.auth-box{background-color:var(--card-bg)}.form-group input{background-color:var(--input-bg);color:var(--text-primary);border:1px solid var(--border-color)}.form-group input:focus{outline:none;border-color:var(--accent-color)}.saved-accounts{margin:20px 0;padding:15px;border-radius:8px;background-color:var(--bg-secondary)}.saved-accounts h3{margin-bottom:12px;font-size:.9em;color:var(--text-secondary)}.account-button{width:100%;padding:10px;margin:5px 0;border:none;background:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.account-button:hover{background-color:var(--bg-tertiary)}.account-info{display:flex;align-items:center;gap:10px}.account-avatar{width:32px;height:32px;border-radius:50%;background-color:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.account-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.account-email{color:var(--text-primary);font-size:.9em}.social-login{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.social-login button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-primary);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s}.social-login button img{width:24px;height:24px}.google-btn:hover{background-color:#f1f3f4}.github-btn{background-color:#24292e!important;color:#fff!important}.github-btn:hover{background-color:#2f363d!important}.divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--text-secondary)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.divider span{padding:0 10px;font-size:.9em}#bt-entrar{width:100%}.home-container{max-width:800px;margin:0 auto}.create-post{background-color:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:30px}.create-post h2{margin-top:0;color:#333}.create-post textarea{width:100%;min-height:100px;padding:10px;border:1px solid #ddd;border-radius:4px;margin-bottom:10px;font-family:inherit}.create-post button{color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer}.feed h2{margin-top:0;color:#333}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.post-header h3{margin:0;color:#333}.post-header span{color:#777;font-size:14px}@media (max-width: 750px){.post-header span{font-size:12px}}.mentions-input-container{position:relative;width:100%}.mentions-textarea{width:100%;min-height:100px;padding:12px;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.95em;resize:vertical;transition:all .2s}.mentions-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.mentions-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 20px #0000001a;z-index:100;max-height:250px;overflow-y:auto;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mention-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:none;cursor:pointer;transition:all .2s ease;border-radius:8px;margin:2px}.mention-item:hover{background:var(--bg-tertiary);transform:translate(4px)}.mention-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color);transition:all .2s ease}.mention-item:hover .mention-avatar{border-color:var(--accent-color);transform:scale(1.05)}.mention-name{color:var(--text-primary);font-weight:500;font-size:.95em;transition:all .2s ease}.mention-item:hover .mention-name{color:var(--accent-color)}.mention{display:inline;color:#1a73e8;font-weight:500;text-decoration:underline;text-decoration-color:#1a73e866;text-decoration-thickness:2px;text-underline-offset:2px;cursor:pointer;padding:2px 0;transition:all .2s ease}.mention:hover{color:#1557b0;text-decoration-color:#1557b0;background:transparent}.mention:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:1px;background:currentColor;opacity:0;transform:scaleX(.8);transition:all .2s ease}.mention:hover:after{opacity:1;transform:scaleX(1)}.mentions-count{position:absolute;bottom:8px;right:8px;font-size:.8em;color:var(--text-secondary)}.mobile-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.mobile-modal-overlay.visible{opacity:1;visibility:visible}.social-post-form{width:90%;max-width:480px;background-color:#fff;border-radius:12px;box-shadow:0 8px 30px #0000001f;overflow:hidden;display:flex;flex-direction:column;animation:slideIn .3s ease forwards}@keyframes slideIn{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.post-form-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #f0f0f0}.post-form-header h3{margin:0;font-size:17px;font-weight:600;color:#262626}.close-button{width:32px;height:32px;background:transparent;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:background-color .2s ease}.close-button:hover{background-color:#f5f5f5}.post-form-user{display:flex;align-items:center;padding:12px 16px;gap:10px}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0}.user-avatar.anonymous{background-color:#f0f0f0;color:#777}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#3b82f6;color:#fff;font-weight:600;font-size:16px}.user-name{font-weight:500;font-size:15px;color:#333}.post-input-container{padding:8px 16px;flex:1;max-height:40vh;overflow-y:auto}.post-textarea{width:100%;min-height:100px;padding:8px 0;border:none;resize:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.5;color:#333}.post-textarea::placeholder{color:#a0a0a0}.post-textarea:focus{outline:none}.post-actions-mobile{padding:10px 16px 16px;display:flex;justify-content:center;flex-direction:column;gap:12px}.action-buttons{display:flex;gap:6px;padding-top:8px;border-top:1px solid #f0f0f0}.action-button{width:36px;height:36px;background:transparent;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#555;transition:background-color .2s ease}.action-button:hover:not(:disabled){background-color:#f0f0f0;color:#333}.action-button:disabled{opacity:.5;cursor:not-allowed}.post-controls-mobile{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.anonymous-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:14px;color:#666}.anonymous-toggle input{margin:0;width:16px;height:16px}.publish-button{display:flex;align-items:center;gap:6px;color:#fff;border:none;border-radius:18px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.publish-button:hover:not(:disabled){background-color:#2563eb}.publish-button:disabled{cursor:not-allowed}.mentions-input-container{width:100%}.mentions-input__suggestions{position:absolute;top:100%;left:0;right:0;max-height:150px;overflow-y:auto;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1}.mentions-input__suggestion{padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px}.mentions-input__suggestion:hover{background-color:#f5f5f5}.mentions-input__suggestion-avatar{width:24px;height:24px;border-radius:50%;background-color:#e0e0e0;display:flex;align-items:center;justify-content:center;overflow:hidden}.mentions-input__suggestion-avatar img{width:100%;height:100%;object-fit:cover}.mentions-input__suggestion-name{font-size:14px;font-weight:500}@media (max-width: 360px){.publish-button{justify-content:center}}.like-button{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;border:1px solid #ddd;background-color:#fff;cursor:pointer;transition:all .2s ease}.like-button:hover{background-color:#f7f7f7}.like-button.liked{background-color:#ffecee;border-color:#ffb3b3}.like-button:disabled{opacity:.7;cursor:not-allowed}.comments-section{margin-top:15px;border-top:1px solid #eee;padding-top:15px;width:100%;display:flex;flex-direction:column}.comment-form{display:flex;flex-direction:column;gap:10px;margin-bottom:15px;width:100%}.comment-form .comment-input{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:8px;font-size:1em;line-height:1.5;resize:vertical;background-color:var(--input-bg);color:var(--text-primary);min-height:60px;transition:all .2s ease;box-shadow:0 2px 4px #0000000d;font-family:inherit}.comment-form .comment-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.comment-form button:disabled{background-color:#ccc;cursor:not-allowed}.comments-list{display:flex;flex-direction:column;gap:10px;width:100%}.comment{background-color:var(--bg-secondary);padding:16px;border-radius:12px;width:100%;transition:background-color .2s;position:relative;margin-bottom:16px;margin-left:max(0px,min(40px,calc(40px * var(--depth))));max-width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word}.comment:hover{background-color:var(--bg-tertiary)}.comment strong{color:#2196f3;margin-right:8px}.comment p{margin:5px 0}.comment small{color:#666;font-size:.8em}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.comment-info{display:flex;flex-direction:column;gap:4px}.comment-author{font-weight:500;color:var(--accent-color)}.comment-date{font-size:.8em;color:var(--text-secondary)}.comment-content{color:var(--text-primary);font-size:.95em;line-height:1.5;margin:8px 0;white-space:pre-wrap;max-width:100%;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.comment-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:.85em;color:var(--text-secondary)}.comment-menu{position:relative;opacity:0;transition:opacity .2s ease}.comment:hover .comment-menu{opacity:1}.comment-menu-trigger{width:32px;height:32px;background:none;border:none;font-size:18px;color:var(--text-secondary);cursor:pointer;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.comment-menu-trigger:hover{background-color:var(--bg-tertiary);color:var(--accent-color)}.comment-menu-dropdown{position:absolute;right:0;top:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);z-index:100;min-width:160px;transform-origin:top right;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.comment-menu-dropdown button{width:100%;padding:10px 16px;display:flex;align-items:center;gap:8px;border:none;background:none;color:var(--text-primary);font-size:.9em;cursor:pointer;transition:all .2s ease}.comment-menu-dropdown button:first-child{border-radius:8px 8px 0 0}.comment-menu-dropdown button:last-child{border-radius:0 0 8px 8px;border-top:1px solid var(--border-color);color:var(--error-color)}.comment-menu-dropdown button:hover{background:var(--bg-tertiary)}.comment-menu-dropdown button span{font-size:1.1em;opacity:.8}.comment-actions{display:flex;gap:8px}.comment-actions button{padding:4px 8px;font-size:12px;background-color:transparent;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#666}.comment-actions button:hover{background-color:#f0f0f0}.comment-actions button{display:flex;align-items:center;gap:4px;padding:6px 12px;font-size:.85em;background:transparent;border:none;cursor:pointer;transition:all .2s ease;border-radius:4px}.comment-actions .edit-btn{color:#2196f3}.comment-actions .edit-btn:hover{background:#2196f31a}.comment-actions .delete-btn{color:#f44336}.comment-actions .delete-btn:hover{background:#f443361a}.comment-actions span{font-size:1.2em}.edit-comment{width:100%;margin:8px 0}.edit-comment input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;margin-bottom:8px}.edit-comment .edit-textarea{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:8px;font-size:1em;line-height:1.5;resize:vertical;background-color:var(--input-bg);color:var(--text-primary);margin-bottom:12px;min-height:60px;transition:all .2s ease;box-shadow:0 2px 4px #0000000d;font-family:inherit}.edit-comment .edit-textarea:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.edit-buttons{display:flex;gap:8px}.edit-buttons button{padding:4px 12px;border:none;border-radius:4px;cursor:pointer}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.comment-content{margin:8px 0}.comment-input-container{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}.comment-input{min-height:100px;resize:vertical}.comment-preview{border:1px solid var(--border-color);border-radius:6px;padding:12px;background:var(--bg-tertiary);min-height:100px;overflow-y:auto}.comments-section.expanded{border-top:1px solid var(--border-color);padding-top:24px;margin-top:24px}.comments-section.expanded .comment{padding:16px;margin-bottom:16px}.comments-section.expanded .comment-form{margin-bottom:24px}.comments-section.expanded .comment-input{min-height:80px}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.comment-time{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.85em}.comment-reply{margin-left:40px;position:relative;padding-left:20px;border-left:2px solid var(--border-color);margin-top:12px;max-width:100%;box-sizing:border-box}.comment-reply:before{content:"";position:absolute;left:0;top:0;width:20px;height:2px;background-color:var(--border-color)}.comment-reply .comment{background-color:var(--bg-tertiary);border:1px solid var(--border-color);margin-bottom:12px}.comment-reply .comment:last-child{margin-bottom:0}.replies-section{margin-top:16px;padding-top:8px;position:relative;margin-left:min(40px,calc(40px * (3 - var(--depth))));max-width:calc(100% - 40px);box-sizing:border-box;overflow:hidden}.replies-section:before{content:"";position:absolute;left:-20px;top:0;bottom:0;width:2px;background:var(--border-color);border-radius:2px}.comment:not(:first-child){margin-top:16px}.comment[style*=margin-left]{position:relative;width:calc(100% - var(--depth) * 40px);margin-right:0}.comment[style*=margin-left]:before{content:"";position:absolute;left:-40px;top:20px;width:32px;height:2px;background:var(--border-color);border-radius:2px}.comment[data-depth="1"]{padding:14px}.comment[data-depth="2"]{padding:12px}.comment[data-depth="3"]{padding:10px}.comment[data-depth="1"] .comment-content{font-size:.95em}.comment[data-depth="2"] .comment-content{font-size:.9em}.comment[data-depth="3"] .comment-content{font-size:.85em}.reply-button{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.9em;padding:4px 8px;border-radius:4px;cursor:pointer;transition:all .2s ease}.reply-button:hover{color:var(--accent-color);background:var(--bg-tertiary)}.reply-form{margin-top:12px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.replies-section{margin-left:40px;margin-top:12px;border-left:2px solid var(--border-color);padding-left:20px;position:relative;display:flex;flex-direction:column;gap:12px}.replies-section:before{content:"";position:absolute;top:0;left:0;width:20px;height:2px;background-color:var(--border-color)}.comment-reply{position:relative;width:100%}.reply-form{margin-top:12px;padding:12px;background:var(--bg-tertiary);border-radius:8px;position:relative}.reply-input{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);resize:vertical;min-height:60px}.reply-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.mentions-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px var(--shadow-color);max-height:200px;overflow-y:auto;z-index:10}.mention-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;border:none;background:none;cursor:pointer;transition:background .2s}.mention-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.mention-info{display:flex;flex-direction:column;gap:2px}.mention-name{font-weight:500;color:var(--text-primary)}.mention-username{font-size:.85em;color:var(--text-secondary)}.mention{color:var(--accent-color);font-weight:500;text-decoration:none;cursor:pointer;background:#2196f31a;padding:2px 4px;border-radius:4px;transition:all .2s}.mention:hover{background:#2196f333;text-decoration:underline}.mentions-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px var(--shadow-color);max-height:200px;overflow-y:auto;z-index:10}.mention-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer}.mention-item:hover{background:var(--bg-tertiary)}.mention-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.reply-btn{color:var(--text-secondary);display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;transition:background .2s}.reply-btn:hover{background:var(--bg-tertiary)}.edit-form{margin:8px 0;width:100%}.edit-textarea{width:100%;min-height:80px;padding:12px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.95em;resize:vertical;margin-bottom:8px}.edit-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f31a}.edit-buttons button{padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .2s}.edit-buttons button:first-child{background:var(--accent-color);color:#fff;border:none}.edit-buttons button:last-child{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.post-actions{display:flex;gap:10px;margin-top:10px}.post-actions button{padding:5px 10px;border:none;border-radius:4px;cursor:pointer;background-color:#f0f0f0}.post-actions button:hover{background-color:#e0e0e0}.edit-post{width:100%}.edit-post textarea{width:100%;min-height:100px;margin-bottom:10px;padding:8px;border:1px solid #ddd;border-radius:4px}.edit-buttons{display:flex;gap:10px}.edit-buttons button{padding:5px 15px;border:none;border-radius:4px;cursor:pointer}.edit-buttons button:first-child{background-color:#4caf50;color:#fff}.edit-buttons button:last-child{background-color:#f44336;color:#fff}.post-card.animate{animation:fadeInUp .5s ease forwards}.loading-spinner{text-align:center;padding:20px;color:var(--text-secondary);animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.post-card:nth-child(1){animation-delay:.1s}.post-card:nth-child(2){animation-delay:.2s}.post-card:nth-child(3){animation-delay:.3s}.post-card:nth-child(4){animation-delay:.4s}.post-card:nth-child(5){animation-delay:.5s}.loading-more{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:var(--text-secondary);font-size:.9em;opacity:0;animation:fadeIn .3s ease forwards}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.post-card{width:100%;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.post-card.visible{opacity:1;transform:translateY(0);animation:slideInUp .5s ease forwards}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.posts-list{scrollbar-width:none;-ms-overflow-style:none;min-height:200px;padding-bottom:20px}.posts-list::-webkit-scrollbar{display:none}@media (max-width: 768px){.post-content-wrapper{padding:15px 12px}.post-actions{align-items:center;flex-wrap:wrap;gap:8px}.post-actions button{flex:1;min-width:80px;justify-content:center}.loading-more{padding:12px}}.official-post{border:2px solid gold;background-color:#fffbea}.profile-container{max-width:800px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:1px solid #ddd}.header h1{color:#3d5af1;margin:0}nav button{cursor:pointer}.profile-info{background-color:var(--bg-secondary);border-radius:16px;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px var(--shadow-color)}.profile-header{display:flex;gap:24px;margin-bottom:24px;justify-content:space-around}.profile-avatar{width:120px;height:120px;min-width:120px;min-height:120px;border-radius:50%;overflow:hidden;background-color:var(--bg-tertiary);flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}@media (max-width: 750px){.profile-avatar{width:80px;height:80px;min-width:80px;min-height:80px}.profile-info{width:100%;padding:0;box-shadow:none;background-color:transparent}}.profile-stats{display:flex;gap:32px;margin-bottom:20px;justify-content:space-around}.stat-item{display:flex;flex-direction:column;align-items:center;cursor:pointer}.stat-value{font-size:1.2rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.9rem;color:var(--text-secondary)}.follow-button{padding:8px 24px;border-radius:20px;border:none;background-color:var(--accent-color);color:#fff;font-weight:500;cursor:pointer;transition:all .2s}.follow-button.following{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.follow-button:hover{filter:brightness(.9)}.profile-details h2{margin-top:0;color:#333}.profile-details p{margin:5px 0;color:#555}.user-posts h2{margin-top:0;color:#333;margin-bottom:20px}.posts-list{display:flex;flex-direction:column;gap:20px}.post-header{margin-bottom:10px}.post-content{margin:10px 0;line-height:1.6}.post-footer{margin-top:15px}.post-footer button{background-color:transparent;border:1px solid #ddd;border-radius:4px;padding:5px 10px;cursor:pointer;color:#555}.post-footer button:hover{background-color:#f5f5f5}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#777}.profile-details>div{margin:8px 0}.info-label{font-weight:500;color:var(--text-secondary);margin-right:8px}.profile-about{margin:16px 0;line-height:1.5;color:var(--text-primary)}.social-link{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;margin:4px;border-radius:16px;background-color:var(--bg-tertiary);color:var(--text-primary);text-decoration:none;font-size:.9em;transition:all .2s ease}.social-link:hover{background-color:var(--accent-color);color:#fff}.sidebar{width:275px;height:100vh;border-right:1px solid var(--border-color);position:sticky;top:0;padding:0 12px;left:0}#icon-sidebar{width:26px;opacity:.85}#icon-sidebar-menuprofile{width:18px;opacity:.85}.sidebar-content{height:100%;display:flex;flex-direction:column;padding:0 12px}.logo{height:64px;display:flex;align-items:center;padding:0 12px}.logo h1{font-size:28px;color:var(--accent-color)}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-item{display:flex;align-items:center;gap:20px;padding:12px 16px;border-radius:9999px;border:none;background:transparent;color:var(--text-primary);font-size:1.2rem;cursor:pointer;transition:background-color .2s;width:fit-content}.nav-item:hover{background-color:var(--bg-secondary)}.nav-item .icon{font-size:1.5rem}.nav-item .label{font-size:1.1rem;font-weight:500}.nav-item.login-btn{color:var(--accent-color)}.nav-item.register-btn{background-color:var(--accent-color);color:#fff}.nav-item.register-btn:hover{filter:brightness(.9)}.profile-section{position:relative;margin-top:auto}.user-profile{padding:12px;border-radius:16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s ease}.dropdown-arrow{margin-left:auto;font-size:.8em;color:var(--text-secondary);transition:transform .2s ease}.user-profile:hover .dropdown-arrow{transform:translateY(2px)}.profile-menu{position:absolute;bottom:100%;left:0;right:0;background-color:var(--bg-secondary);border-radius:12px;box-shadow:0 4px 12px var(--shadow-color);margin:0 12px 8px;overflow:hidden;opacity:0;transform:translateY(10px);animation:slideIn .2s ease forwards}.menu-header{padding:16px}.menu-user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.profile-link{width:100%;text-align:left;padding:8px 0;color:var(--accent-color)!important;font-size:.9em}.section-title{display:block;padding:8px 16px;font-size:.8em;color:var(--text-secondary)}.account-item{display:flex;align-items:center;padding:4px 8px}.account-button{flex:1;display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px}.account-button.active{background-color:var(--bg-tertiary)}.account-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;background-color:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff}.add-account{color:var(--accent-color)!important;padding:12px 16px}.profile-menu button{width:100%;padding:12px 16px;display:flex;align-items:center;gap:8px;border:none;background:none;color:var(--text-primary);font-size:.95em;cursor:pointer;transition:background-color .2s}.profile-menu button:hover{background-color:var(--bg-tertiary)}.profile-menu hr{border:none;border-top:1px solid var(--border-color);margin:4px 0}.profile-menu .logout-btn{color:#f44336}.profile-menu .logout-btn:hover{background-color:#f443361a}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:none;color:var(--text-primary);font-size:.95em;cursor:pointer;transition:background-color .2s}.menu-item:hover{background-color:var(--bg-tertiary)}.menu-item.logout-btn{color:#f44336}.menu-item.logout-btn:hover{background-color:#f443361a}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.user-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-info{display:flex;flex-direction:column}.user-email{font-size:.9rem;color:var(--text-secondary)}.user-info{display:flex}.accounts-section{padding:4px 0}.account-item{display:flex;align-items:center;justify-content:space-between;padding:0 4px}.account-item button{padding:8px 12px}.account-item button.active{background-color:var(--bg-tertiary);color:var(--accent-color)}.remove-account{padding:4px 8px!important;color:var(--text-secondary)!important;font-size:1.2em!important}.remove-account:hover{color:#f44336!important}.notifications-button{position:relative}.notification-badge{position:absolute;top:-5px;right:-5px;background:var(--accent-color);color:#fff;border-radius:50%;min-width:18px;height:18px;font-size:12px;display:flex;align-items:center;justify-content:center;padding:2px}@media (max-width: 1020px){.sidebar{width:88px}.user-info{display:none}}@media (max-width: 500px){.sidebar{position:fixed;bottom:0;left:0;width:100%;height:60px;background-color:var(--bg-primary);border-top:1px solid var(--border-color);padding:0;z-index:1000}.sidebar-content{padding:0}.logo,.user-profile{display:none}.sidebar-nav{flex-direction:row;justify-content:space-around;padding:0 16px}.nav-item{padding:8px}.nav-item .icon{font-size:1.3rem}}@media (max-width: 768px){.sidebar{display:none}}.nav-item[data-path="/chat"] .icon{color:var(--accent-color)}.nav-item[data-path="/chat"]{position:relative}.nav-item[data-path="/chat"]:hover{background:#2196f31a}.nav-item[data-path="/chat"].active{color:var(--accent-color);background:#2196f31a}.sidebar-right{width:320px;height:100vh;position:sticky;top:0;padding:20px 0;overflow-y:auto}.suggestions-wrapper{background-color:var(--bg-secondary);border-radius:16px;padding:16px;position:sticky;top:20px}.suggestions-wrapper h2{font-size:1.2rem;margin-bottom:16px;color:var(--text-primary)}.suggestions-list{display:flex;flex-direction:column;gap:12px}.suggestion-item{display:flex;align-items:center;padding:12px;border-radius:12px;transition:all .2s ease;width:100%;gap:12px}.suggestion-item:hover{background-color:var(--bg-tertiary)}.user-info{display:flex;gap:12px;cursor:pointer;flex:1;min-width:0}.user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;background-color:var(--accent-color);display:flex;align-items:center;justify-content:center;color:#fff}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-details{display:flex;flex-direction:column;gap:2px;flex:1;max-width:calc(100% - 100px)}.user-name{font-weight:500;color:var(--text-primary);text-overflow:ellipsis;line-height:1.2}.user-course{width:190px;font-size:.9rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.follow-button{flex-shrink:0;width:80px;text-align:center;padding:6px 16px;border-radius:20px;border:none;background-color:var(--accent-color);color:#fff;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;margin-left:12px}.follow-button:hover{background-color:var(--accent-color);filter:brightness(.9)}@media (max-width: 1200px){.sidebar-right{display:none}}.calendar{background-color:#fff;border-radius:8px;padding:16px;margin-top:20px;box-shadow:0 2px 4px #0000001a}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-header button{background:none;border:none;cursor:pointer;font-size:18px;color:#666}.calendar-header h3{margin:0;font-size:16px;color:#333}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.weekday{text-align:center;font-size:12px;font-weight:700;color:#666;padding:4px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;border-radius:4px;position:relative}.calendar-day:hover{background-color:#f0f0f0}.calendar-day.empty{background:none;cursor:default}.calendar-day.today{background-color:#007bff;color:#fff}.event-badge{position:absolute;bottom:2px;right:2px;background-color:#ff4081;color:#fff;font-size:10px;width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center}.event-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.event-modal-content{background:#fff;padding:20px;border-radius:8px;width:300px;position:relative}.event-modal-content input,.event-modal-content select{width:100%;padding:8px;margin:8px 0;border:1px solid #ddd;border-radius:4px}.close-button{position:absolute;right:10px;top:10px;border:none;background:none;font-size:20px;cursor:pointer}.event-list{margin-top:15px}.event-item{padding:10px;margin:5px 0;border-radius:4px;display:flex;justify-content:space-between;align-items:center}.event-item.exam{background-color:#ffebee}.event-item.assignment{background-color:#e3f2fd}.event-item.presentation{background-color:#e8f5e9}.event-type{font-size:12px;color:#666}.add-event-button{width:100%;padding:8px;margin-top:10px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.add-event-button:hover{background-color:#0056b3}.event-modal-content button{padding:8px 16px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;margin-top:10px}.notifications-dropdown{position:absolute;top:60px;right:20px;width:320px;max-height:480px;background:var(--bg-primary);border-radius:12px;box-shadow:0 4px 20px var(--shadow-color);z-index:1000;display:flex;flex-direction:column;animation:dropIn .2s cubic-bezier(.21,1.02,.73,1);transform-origin:top right;overflow:hidden}@keyframes dropIn{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes dropOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.9) translateY(-10px)}}.notifications-dropdown.closing{animation:dropOut .2s cubic-bezier(.21,1.02,.73,1);pointer-events:none}.notifications-header{padding:16px;border-bottom:1px solid var(--border-color)}.notifications-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.notifications-list{overflow-y:auto;max-height:400px;padding:8px 0}.notification-item{padding:12px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background-color .2s}.notification-item:hover{background-color:var(--bg-secondary)}.notification-item.unread{background-color:var(--bg-tertiary)}.notification-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden}.notification-avatar img{width:100%;height:100%;object-fit:cover}.notification-content{flex:1}.notification-content p{margin:0;color:var(--text-primary);font-size:.9rem;line-height:1.4}.notification-time{font-size:.8rem;color:var(--text-secondary)}.no-notifications{padding:20px;text-align:center;color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.notifications-dropdown{position:fixed;top:0;right:0;left:0;width:100%;max-height:100vh;border-radius:0;animation:slideUp .3s cubic-bezier(.21,1.02,.73,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.notifications-dropdown.closing{animation:slideDown .3s cubic-bezier(.21,1.02,.73,1)}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.notifications-list{max-height:none;height:calc(100% - 60px)}}.mobile-nav{position:fixed;bottom:0;left:0;right:0;width:100vw;background:#fff;box-shadow:0 -2px 16px #00000012;display:flex;justify-content:space-around;align-items:center;z-index:100;padding:8px 0}.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000;z-index:998;transition:background .4s ease}.overlay.open{background:#00000080}.overlay-menu{position:fixed;bottom:-100%;left:0;right:0;background:var(--bg-primary);border-radius:16px 16px 0 0;box-shadow:0 -4px 10px #0003;z-index:1001;padding:20px;transition:transform .4s cubic-bezier(.25,.8,.25,1);transform:translateY(100%)}.overlay-menu.open{transform:translateY(0)}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slide-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}.overlay-menu-header{display:flex;justify-content:flex-end}.close-overlay-menu{background:none;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer}.overlay-menu-items{list-style:none;padding:0;margin:20px 0 0}.overlay-menu-item{margin:10px 0}.overlay-menu-item button{background:none;border:none;color:var(--text-primary);font-size:1.2rem;cursor:pointer;transition:color .2s ease}.overlay-menu-item button:hover{color:var(--accent-color)}.profile-menu-mobile{gap:20px;position:fixed;bottom:0;left:0;right:0;background:var(--bg-primary);border-radius:16px 16px 0 0;box-shadow:0 -4px 10px #0003;padding:36px;z-index:1001;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .1s ease-in-out;animation:slide-down .4s cubic-bezier(.25,.8,.25,1) forwards}.profile-menu-mobile.open{transform:translateY(0);animation:slide-up .3s ease-in-out forwards}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;transition:background .2s ease-out}.mobile-menu-overlay.hidden{background:#0000}.menu-header-mobile{display:flex;align-items:center;margin-bottom:16px}.user-info-mobile{display:flex;align-items:center}.user-avatar-mobile{width:40px;height:40px;border-radius:50%;margin-right:8px}.user-name-mobile{font-size:1rem;font-weight:700}.menu-items-mobile{display:flex;flex-direction:column;align-items:flex-start;gap:10px}.menu-item-mobile{background:none;border:none;color:var(--text-primary);text-align:left;font-size:1rem;cursor:pointer;padding:8px 0;display:flex;align-items:flex-start;transition:color .3s ease}.menu-item-mobile:hover{color:var(--accent-color)}.icon-mobile{font-size:1.5rem;margin-right:8px}.label-mobile{font-size:1rem}.logout-btn-mobile{color:var(--error-color)}.logout-btn-mobile:hover{color:var(--error-color-hover)}.badge{position:absolute;top:5px;right:10px;background:var(--accent-color);color:#fff;font-size:.7rem;padding:2px 6px;border-radius:50%}.nav-item-mobile{background:none!important;border:none;outline:none;color:#222;font-size:1.7rem;display:flex;align-items:center;justify-content:center}.mobile-submenu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000052;display:flex;align-items:flex-end;justify-content:center;z-index:1200;animation:fadeIn .2s}.mobile-submenu{background:#fff;border-radius:22px 22px 0 0;box-shadow:0 -4px 32px #00000021;padding:32px 0 24px;display:flex;flex-direction:column;gap:12px;min-width:100vw;max-width:480px;align-items:stretch;animation:submenuSlideUp .25s cubic-bezier(.25,.8,.25,1)}.submenu-item-mobile{font-size:1.18rem!important;font-weight:700!important;color:#1565c0!important;border-radius:14px!important;padding:18px 24px!important;margin:0 18px;justify-content:flex-start!important;text-transform:none!important;box-shadow:none!important;border:none!important;transition:background .18s,color .18s;display:flex!important;align-items:center!important;gap:14px}.profile-icon-container{display:flex;align-items:center;justify-content:center}.profile-icon-image{width:24px;height:24px;border-radius:50%;object-fit:cover}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000040;z-index:300}body,html,#root{width:100vw;overflow-x:hidden}.nav-item-mobile:hover{color:var(--accent-color)}.nav-item-mobile .icon{font-size:1.5rem;width:26px;height:26px;margin-bottom:4px;opacity:.8}.icon-mobile{width:26px;opacity:.8}.nav-item-mobile .label{font-size:.75rem;margin-top:4px}@media (min-width: 750px){.mobile-nav{display:none}}@keyframes fadeIn{0%{background:#0000}to{background:#00000052}}@media (max-width: 600px){.mobile-submenu{min-width:100vw;padding:24px 0 16px}}@keyframes submenuSlideUp{0%{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 600px){.mobile-submenu{padding:24px 8px}}.chat-container{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);position:relative}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 12px 70px;display:flex;flex-direction:column;gap:8px;scroll-behavior:smooth;margin-bottom:20px}.messages-container>*{transition:transform .3s ease-out}.message{max-width:90%;padding:12px 16px;border-radius:16px;margin-bottom:8px;font-size:1rem;line-height:1.5;box-shadow:0 2px 8px #0000000a;word-break:break-word;transition:background .2s;animation:messageIn .3s ease}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.sent{align-self:flex-end;background:linear-gradient(120deg,var(--accent-color),#1976d2);color:#fff;border-bottom-right-radius:4px;margin-left:10%}.message.received{align-self:flex-start;background:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px;margin-right:10%}.message-content{margin-bottom:4px;word-wrap:break-word;white-space:pre-wrap}.message-time{font-size:.7rem;opacity:.7;text-align:right}.message-form{padding:12px;display:flex;gap:8px;border-top:1px solid var(--border-color);background:var(--bg-primary);position:fixed;bottom:0;left:0;right:0;width:100%;z-index:100;box-shadow:0 -2px 10px #0000000d}.message-form input{flex:1;padding:10px 16px;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-secondary);color:var(--text-primary);font-size:.92rem;transition:all .2s}.message-form input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 3px #2196f31a}.message-form button{padding:0 16px;border:none;border-radius:20px;background:var(--accent-color);color:#fff;font-size:.92rem;font-weight:500;transition:all .2s}.message-form button:hover{filter:brightness(1.1);transform:translateY(-1px)}.message-form button:active{transform:translateY(0)}.chat-loading,.chat-no-access{padding:24px;text-align:center;color:var(--text-secondary)}.chat-no-access{background:var(--bg-secondary);border-radius:12px;margin:16px}.message-info{display:flex;align-items:center;justify-content:flex-end;gap:4px;font-size:.7rem;opacity:.7}.message-status{color:var(--accent-color);font-size:1.1em;margin-left:4px}.message-status.read{color:#4caf50}.message.sent .message-status{color:#fff}.message.sent .message-status.read{color:#98ff98}.typing-indicator{padding:8px 16px;color:var(--text-secondary);align-self:flex-start;margin:8px 0;font-size:0;transform-origin:bottom left;animation:slideIn .3s ease-out}.typing-indicator span{display:inline-block;width:8px;height:8px;margin:0 2px;background:currentColor;border-radius:50%;opacity:.4}.typing-indicator span:nth-child(1){animation:typingDot 1s infinite 0s}.typing-indicator span:nth-child(2){animation:typingDot 1s infinite .2s}.typing-indicator span:nth-child(3){animation:typingDot 1s infinite .4s}@keyframes typingDot{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@keyframes blink{0%,to{transform:scale(.5);opacity:.2}50%{transform:scale(1);opacity:1}}@keyframes bounce{0%,80%,to{transform:scale(0);opacity:.2}40%{transform:scale(1);opacity:1}}@media (min-width: 769px){.messages-container{padding:32px 32px 90px;gap:16px}.message{max-width:60%;padding:16px;font-size:1.05rem}.message-form{padding:24px 32px}}@media (max-width: 768px){.chat-container{height:calc(100% - 60px)}.message{max-width:80%}.message-form{padding:16px}}@media (max-width: 600px){.chat-container{height:calc(100vh - 56px)}.message{font-size:.95rem;padding:10px 12px;max-width:95%}.message-form{padding:10px}}.chat-popup{position:fixed;bottom:20px;right:20px;width:320px;height:480px;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:9999;max-height:calc(100vh - 80px);resize:both;overflow:hidden;min-width:280px;min-height:400px;animation:slideUp .2s ease}.chat-popup.minimized{height:56px!important;resize:none;min-height:56px;animation:shrinkChat .2s ease}.chat-popup.minimized .chat-content{display:none}.chat-popup:not(.minimized){animation:expandChat .3s ease}.chat-header{height:56px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);flex-shrink:0}.chat-recipient{display:flex;align-items:center;gap:10px;max-width:calc(100% - 80px)}.recipient-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}.recipient-name{font-weight:500;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-controls{display:flex;gap:6px}.chat-controls button{width:28px;height:28px;border:none;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:16px}.minimize-btn{background:var(--bg-tertiary);color:var(--text-primary)}.minimize-btn:hover{background:var(--bg-secondary);transform:translateY(-1px)}.close-btn{background:#f443361a;color:#f44336}.close-btn:hover{background:#f44336;color:#fff}.chat-content{flex:1;overflow:hidden;display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shrinkChat{0%{height:480px}to{height:56px}}@keyframes expandChat{0%{height:56px}to{height:480px}}@media (max-width: 768px){.chat-popup{display:none}}.app-container{position:relative;display:grid;grid-template-columns:275px minmax(auto,600px) 320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.main-content{position:relative;grid-column:2;min-width:0;z-index:1;background-color:var(--bg-primary);width:100%;margin:0 auto;height:100vh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.main-content::-webkit-scrollbar{display:none}.main-content.no-scroll{overflow:hidden!important;height:100vh!important;touch-action:none!important}.sidebar{position:fixed;left:max(0px,calc(50% - 650px));top:0;height:100vh;overflow-y:auto}.sidebar-right{position:fixed;right:max(0px,calc(50% - 650px));top:0;height:100vh;overflow-y:auto}.app-container>*:last-child{border-right:none}@media (max-width: 1200px){.app-container{grid-template-columns:275px 1fr;max-width:900px}.sidebar-right{display:none}}@media (max-width: 1020px){.app-container{grid-template-columns:88px minmax(auto,600px);max-width:700px}}@media (max-width: 768px){.app-container{grid-template-columns:1fr;max-width:600px;padding-bottom:60px;padding-top:5px}.sidebar{position:fixed;bottom:0;left:0;width:100%;height:60px;background:var(--bg-primary);border-top:1px solid var(--border-color);z-index:1000;padding:0}.sidebar-content{height:100%}.sidebar-nav{flex-direction:row;justify-content:space-around;height:100%;padding:0 16px}.logo,.user-profile,.sidebar .profile-section{display:none}.main-content{padding:10px;width:95vw}}@media (max-width: 768px){.app-container{grid-template-columns:1fr;padding-bottom:60px}.sidebar,.sidebar-right{display:none}}@media (max-width: 500px){.app-container{grid-template-columns:1fr;padding-bottom:60px}}@media (max-width: 480px){.notifications-dropdown{position:fixed;top:0;left:0;right:0;width:100%;max-height:none;border-radius:0;z-index:999}.notifications-list{max-height:none;height:calc(100% - 60px)}}.settings-container{max-width:600px;margin:0 auto;padding:20px}.settings-section{background-color:var(--bg-secondary);border-radius:8px;padding:20px;margin-bottom:20px}.settings-form{display:flex;flex-direction:column;gap:16px}.settings-form textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--input-bg);color:var(--text-primary);resize:vertical;min-height:100px;font-family:inherit}.form-group{display:flex;flex-direction:column;gap:8px}.form-group input{padding:12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--input-bg);color:var(--text-primary)}.alert{padding:12px;border-radius:6px;margin-bottom:20px}.alert.success{background-color:#4caf50;color:#fff}.alert.error{background-color:#f44336;color:#fff}.danger-zone{border:1px solid #f44336}.delete-account{background-color:#f44336;color:#fff;border:none;padding:12px;border-radius:6px;cursor:pointer}.delete-account:hover{background-color:#d32f2f}button{padding:12px;border-radius:6px;border:none;background-color:var(--accent-color);color:#fff;cursor:pointer;font-weight:500;transition:all .2s ease}button:hover{filter:brightness(.9)}button:disabled{opacity:.7;cursor:not-allowed}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:var(--bg-primary);padding:24px;border-radius:12px;width:90%;max-width:400px}.modal-content h3{margin-bottom:12px}.modal-content p{margin-bottom:20px;color:var(--text-secondary)}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.cancel-btn{background-color:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.cancel-btn:hover{background-color:var(--bg-secondary)}.social-links-section{border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.social-links-section h3{margin-bottom:16px;color:var(--text-primary)}.school-input-container{display:flex;gap:8px;align-items:center}.suggest-school-btn{padding:8px 12px;font-size:.9em;background-color:transparent;color:var(--accent-color);border:1px solid var(--accent-color)}select{padding:12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--input-bg);color:var(--text-primary);width:100%;cursor:pointer}.photo-upload{display:flex;align-items:center;gap:20px;margin-bottom:20px}.current-photo{width:100px;height:100px;border-radius:50%;overflow:hidden;background-color:var(--bg-tertiary)}.current-photo img{width:100%;height:100%;object-fit:cover}.upload-controls{display:flex;flex-direction:column;gap:8px}.upload-controls input[type=file]{display:none}.upload-button{padding:8px 16px;background-color:var(--accent-color);color:#fff;border-radius:4px;cursor:pointer;text-align:center;transition:all .2s}.upload-button:hover{filter:brightness(.9)}.crop-modal .modal-content{max-width:90vw;max-height:90vh;overflow:hidden}.crop-container{margin:20px 0;max-height:70vh;overflow:hidden}.ReactCrop{max-height:70vh}.ReactCrop__crop-selection{border-radius:50%}.ReactCrop__image{max-height:70vh;width:auto}.discord-connect-btn{display:inline-flex;align-items:center;background:#5865f2;color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s;margin-top:8px;margin-bottom:8px;box-shadow:0 2px 8px #5865f214}.discord-connect-btn:hover{background:#4752c4}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media (pointer: coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.page-container{width:100%;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);padding-top:20px}.page-wrapper{width:100%;min-height:calc(100vh - 60px);background:var(--bg-primary);padding:20px;display:flex;justify-content:center}.post-view{position:relative;width:100%;max-width:600px;margin:0 auto;padding:0 20px;grid-column:2;z-index:2}.post-container{width:100%;max-width:600px;margin:0 auto;flex:1;display:flex;flex-direction:column}.post-card.detailed{position:relative;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px var(--shadow-color);z-index:2}@media (min-width: 768px){.post-card{width:100%;background:var(--bg-secondary);border-radius:12px;padding:20px;box-shadow:0 2px 8px var(--shadow-color);border:1px solid var(--border-color);margin-bottom:20px;transform:translateY(20px);animation:fadeInUp .3s ease-out forwards;will-change:transform,opacity}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.back-button{margin-bottom:16px;padding:8px 16px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;font-size:1rem;display:flex;align-items:center;gap:8px}.back-button{background:transparent;border:none;color:var(--text-primary);padding:8px 0;margin-bottom:16px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:1rem}.post-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.author-info{display:flex;align-items:center;gap:12px}.author-info.clickable{cursor:pointer;transition:opacity .2s}.author-info.clickable:hover{opacity:.8}.author-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.anonymous-avatar{width:48px;height:48px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary)}.author-name{font-size:1.1em;font-weight:500;color:var(--text-primary)}.post-content{font-size:1.1em;line-height:1.6;color:var(--text-primary);margin:16px 0;white-space:pre-wrap}.error-container{background:var(--bg-secondary);border-radius:16px;padding:24px;text-align:center;margin-bottom:20px;box-shadow:0 2px 8px var(--shadow-color)}.error-container h2{color:var(--text-primary);margin-bottom:16px}.error-container button{padding:8px 16px;background-color:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.error-container button:hover{filter:brightness(.9)}.loading{text-align:center;padding:24px;color:var(--text-primary)}.post-stats{width:100%;padding:16px 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin:16px 0;color:var(--text-secondary);font-size:.9em}.post-menu{position:relative}.menu-trigger{background:none;border:none;font-size:20px;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%}.menu-trigger:hover{background:var(--bg-tertiary)}.menu-dropdown{position:absolute;right:0;top:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px var(--shadow-color);z-index:10;min-width:150px;animation:fadeIn .2s ease}.menu-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:none;color:var(--text-primary);cursor:pointer;transition:background .2s}.menu-dropdown button:hover{background:var(--bg-tertiary)}.menu-dropdown button:last-child{color:var(--error-color)}.edit-post{width:100%;margin:16px 0}.edit-textarea{width:100%;min-height:120px;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);margin-bottom:12px;resize:vertical}.edit-buttons{display:flex;gap:8px;justify-content:flex-end}@media (max-width: 1200px){.post-view{margin-right:0}}@media (max-width: 1020px){.post-view{margin-left:88px}}@media (max-width: 768px){.page-container{padding-top:0}.post-view{padding:0}.post-card.detailed{border-radius:0;margin-bottom:60px}.page-wrapper{padding:0}.post-container{max-width:100%}.post-card{border-radius:0;margin-bottom:60px}.back-button{padding:12px 20px;margin:0;border-bottom:1px solid var(--border-color)}}.chat-list{height:100%;background:var(--bg-primary);display:flex;flex-direction:column}.chat-list-header{padding:20px;border-bottom:1px solid var(--border-color)}.chat-list-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.chats-container{flex:1;overflow-y:auto;padding:12px}.chat-item{display:flex;align-items:center;gap:12px;padding:16px;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.chat-item:hover{background:var(--bg-secondary)}.chat-item.unread{background:var(--bg-tertiary)}.chat-avatar{position:relative;width:48px;height:48px}.chat-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.online-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:#4caf50;border:2px solid var(--bg-primary);border-radius:50%}.chat-info{flex:1;min-width:0}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.chat-name{font-weight:500;color:var(--text-primary)}.chat-time{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.chat-preview{display:flex;justify-content:space-between;align-items:center;gap:8px}.chat-preview p{margin:0;font-size:.9rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-preview .no-messages{font-style:italic;opacity:.7}.unread .chat-preview p{font-weight:500;color:var(--text-primary)}.unread-count{background:var(--accent-color);color:#fff;font-size:.8rem;padding:2px 6px;border-radius:12px;min-width:20px;text-align:center}.no-chats{text-align:center;padding:40px 20px;color:var(--text-secondary)}.no-chats p{margin:0 0 8px;font-size:1.1rem}.no-chats small{font-size:.9rem}.suggested-chats{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color)}.suggested-chats h3{font-size:1.1rem;color:var(--text-primary);margin-bottom:16px;padding:0 16px}.suggested-user{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;cursor:pointer;transition:all .2s}.suggested-user:hover{background:var(--bg-secondary)}.user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.user-info{flex:1;display:flex;flex-direction:column;gap:4px}.user-name{font-weight:500;color:var(--text-primary)}.user-course{font-size:.9rem;color:var(--text-secondary)}.start-chat-btn{padding:8px 16px;border-radius:20px;background:var(--accent-color);color:#fff;border:none;cursor:pointer;transition:all .2s}.start-chat-btn:hover{filter:brightness(1.1)}@media (max-width: 768px){.chat-list{height:calc(100vh - 60px)}}.chat-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);position:relative}.chat-header{height:64px;padding:0 16px;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);position:sticky;top:0;z-index:10}.back-button{width:40px;height:40px;border:none;background:var(--bg-secondary);color:var(--text-primary);border-radius:50%;cursor:pointer;font-size:20px;transition:all .2s;display:flex;align-items:center;justify-content:center}.back-button:hover{background:var(--bg-tertiary);transform:translate(-2px)}.recipient-info{display:flex;align-items:center;gap:12px}.recipient-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.recipient-name{font-size:1.1rem;font-weight:500;color:var(--text-primary)}@media (min-width: 769px){.chat-page{max-width:1000px;height:calc(100vh - 40px);overflow:hidden}.chat-header{height:72px;padding:0 24px}.recipient-avatar{width:48px;height:48px}.recipient-name{font-size:1.2rem}}@media (max-width: 768px){.chat-page{height:calc(100vh - 60px);margin:0;padding-bottom:60px}}@media (max-width: 768px){.chat-page{position:fixed;top:0;left:0;right:0;bottom:0;height:100vh;width:100vw;margin:0;border-radius:0;z-index:1000;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}}.chat-list-page{height:100vh;width:100%;max-width:800px;margin:0 auto;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}@media (max-width: 768px){.chat-list-page{height:calc(100vh - 60px);border-radius:0;border:none}}.chat-popup{position:fixed;bottom:20px;right:20px;width:380px;height:600px;max-height:calc(100vh - 40px);margin:0;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 4px 20px var(--shadow-color);overflow:hidden;z-index:1000;animation:slideUp .3s ease}.chat-page.mobile{width:100%;height:100vh;position:fixed;top:0;left:0}.chat-page.desktop{width:350px;height:500px;border-radius:8px;box-shadow:0 2px 10px #0000001a;background:#fff;overflow:hidden}.chat-page.desktop .chat-header{cursor:move}@font-face{font-family:SF Pro Display;src:url(/assets/SF-Pro-Display-Regular-2nqpBkwV.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:SF Pro Display;src:url(/assets/SF-Pro-Display-Medium-BBxWjZ4E.otf) format("opentype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:SF Pro Display;src:url(/assets/SF-Pro-Display-Bold-BTSGLTri.otf) format("opentype");font-weight:700;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box;font-family:SF Pro Display,system-ui,-apple-system,sans-serif!important;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-primary)}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #ffffff;--text-primary: #333333;--text-secondary: #666666;--accent-color: #2196F3;--border-color: #e0e0e0;--card-bg: #ffffff;--shadow-color: rgba(0, 0, 0, .1);--input-bg: #ffffff;--hover-bg: #f0f0f0}[data-theme=dark]{--bg-primary: #15202b;--bg-secondary: #1e2732;--bg-tertiary: #2c3640;--text-primary: #ffffff;--text-secondary: #8899a6;--accent-color: #1da1f2;--border-color: #38444d;--card-bg: #1e2732;--shadow-color: rgba(0, 0, 0, .3);--input-bg: #253341;--hover-bg: #283340}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:all .3s ease}.app{max-width:800px;margin:0 auto;padding:20px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #ddd;margin-bottom:20px}.app-header h1{color:#4267b2;font-size:24px}.user-info{display:flex;gap:15px}.logout-button{background:none;border:1px solid #ddd;padding:5px 10px;border-radius:5px;cursor:pointer}.logout-button:hover{background-color:#f5f5f5}.login-container{max-width:500px;margin:50px auto;padding:30px;background-color:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;text-align:center}.login-container h2{margin-bottom:15px;color:#4267b2}.login-container p{margin-bottom:30px;color:#666}.primary-button{background-color:#4267b2;color:#fff;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-weight:700}.primary-button:hover{background-color:#365899}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:30px;border-radius:10px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h3{margin-bottom:20px;color:#4267b2}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:5px;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:16px}.form-group textarea{min-height:100px;resize:vertical}.form-group.checkbox{display:flex;align-items:center}.form-group.checkbox label{display:flex;align-items:center;gap:10px;margin:0}.form-group.checkbox input{width:auto}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.new-post-button{width:100%;padding:15px;background-color:#fff;border:1px dashed #ccc;border-radius:10px;cursor:pointer;font-size:16px;color:#4267b2}.new-post-button:hover{background-color:#f9f9f9}.image-preview{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.preview-thumbnail{width:80px;height:80px;border-radius:5px;overflow:hidden}.preview-thumbnail img{width:100%;height:100%;object-fit:cover}.posts-feed{display:flex;flex-direction:column;gap:20px}.post{background-color:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px #0000001a}.post-header{display:flex;justify-content:space-between;margin-bottom:15px}.author-name{font-weight:700;margin-right:5px}.author-college{color:#666;font-size:14px}.post-content{margin-bottom:15px;white-space:pre-wrap}.post-images{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.post-image{max-width:100%;max-height:400px;border-radius:5px}.post-actions button{background:none;border:none;cursor:pointer;color:#666}.post-actions button:hover{color:#4267b2}.post-comments{margin-top:15px;border-top:1px solid #eee;padding-top:15px}.comment{margin-bottom:10px;padding:10px;background-color:#f9f9f9;border-radius:5px}.comment-author{font-weight:500;margin-bottom:5px}.comment-form{display:flex;gap:10px;margin-top:15px}.comment-form input{flex:1;padding:10px;border:1px solid #ddd;border-radius:20px}.comment-form button{background-color:#4267b2;color:#fff;border:none;padding:5px 15px;border-radius:20px;cursor:pointer}.empty-feed{text-align:center;padding:50px 0;color:#999}@media (max-width: 600px){.app{padding:10px}.modal-content{padding:20px;width:95%}.post-images{flex-direction:column}}@media (max-width: 768px){body,html{overflow-x:hidden;width:100%;position:relative}#root{overflow-x:hidden}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}h1{font-size:2rem;color:var(--accent-color)}h2{font-size:1.5rem;margin-bottom:5px}ul{padding-left:20px}li{margin-bottom:5px}.divpai_versao,.divfilha_versao{margin-bottom:10px;padding:10px;border:1px solid #ccc;border-radius:5px}@media (max-width: 768px){.divpai_versao{margin-bottom:20px;border:none;padding:0}}.goals-page .goals-container{max-width:420px;margin:40px auto;background:#fff;border-radius:24px;box-shadow:0 4px 32px #00000012;padding:32px 24px}.goals-page .goals-container h2{font-size:1.7rem;font-weight:700;margin-bottom:24px;text-align:center;color:#222}.goals-page form{display:flex;flex-direction:column;gap:18px;margin-bottom:32px}.goals-page input[type=text],.goals-page input[type=date],.goals-page textarea,.goals-page select{border:1px solid #e0e0e0;border-radius:14px;padding:14px 16px;font-size:1rem;background:#fafbfc;transition:border .2s;outline:none}.goals-page input:focus,.goals-page textarea:focus,.goals-page select:focus{border-color:#007aff;background:#fff}.goals-page textarea{min-height:60px;resize:vertical}.goals-page button[type=submit]{background:#222;color:#fff;border:none;border-radius:14px;padding:14px 0;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .2s}.goals-page button[type=submit]:hover{background:#007aff}.goals-page button[type=button]{background:#f5f5f7;color:#222;border:none;border-radius:14px;padding:12px 0;font-size:1rem;margin-left:8px;cursor:pointer;transition:background .2s}.goals-page .goal-item{background:#fafbfc;border-radius:16px;padding:18px 16px;margin-bottom:18px;box-shadow:0 2px 8px #00000008;display:flex;flex-direction:column;gap:6px}.goals-page .goal-item.completed{opacity:.7;text-decoration:line-through}.goals-page .goal-item h3{font-size:1.15rem;font-weight:600;margin:0 0 4px}.goals-page .goal-item p{margin:0;color:#555;font-size:.98rem}.goals-page .goal-item button{margin-top:10px;margin-right:8px;padding:8px 18px;border-radius:10px;border:none;background:#f5f5f7;color:#222;font-weight:500;cursor:pointer;transition:background .2s}.goals-page .goal-item button:hover{background:#e0e0e0}.goals-page .modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000002e;display:flex;align-items:center;justify-content:center;z-index:1000}.goals-page .modal-content{background:#fff;border-radius:18px;padding:32px 28px;box-shadow:0 4px 32px #00000017;text-align:center}.goals-page .modal-content p{font-size:1.1rem;margin-bottom:24px}.goals-page .modal-content button{margin:0 10px;padding:10px 28px;border-radius:12px;border:none;font-size:1rem;font-weight:500;background:#222;color:#fff;cursor:pointer;transition:background .2s}.goals-page .modal-content button:last-child{background:#f5f5f7;color:#222}@media (max-width: 600px){.goals-page .goals-container{padding:18px 6px;border-radius:0;box-shadow:none}.goals-page .modal-content{padding:18px 8px}}.study-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:32px 0 0;background:#fff}.study-page h2{font-size:2rem;font-weight:700;margin-bottom:24px;letter-spacing:1px;color:#111}.streak-display{margin-bottom:24px;font-size:1.2rem;font-weight:500;color:#111;background:#f8f8f8;border-radius:16px;padding:10px 24px;box-shadow:0 2px 12px #00000008;display:inline-block;-webkit-user-select:none;user-select:none}.study-timer-container{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.study-timer-circle{width:160px;height:160px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;margin-bottom:18px;box-shadow:0 4px 24px #0000000a}.study-timer-circle-inner{width:120px;height:120px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#111;cursor:pointer;transition:background .2s,color .2s;-webkit-user-select:none;user-select:none;border:2px solid #222}.study-timer-circle-inner.paused{color:#888;background:#f8f8f8;border:2px dashed #bbb}.study-timer-time{font-size:2.1rem;font-weight:700;color:#111;margin-bottom:10px;letter-spacing:2px}.study-timer-buttons{margin-top:10px}.study-timer-buttons button{padding:8px 22px;font-size:1.1rem;border-radius:8px;border:1px solid #222;background:#fff;color:#111;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.study-timer-buttons button:disabled{background:#eee;color:#aaa;border-color:#ccc;cursor:not-allowed}.tabs-container{width:100%;margin:0 auto 24px;background:#fff;border-radius:18px;padding:0}.tabs-header{display:flex}.tab-btn{flex:1;padding:14px 0;background:none;border:none;font-size:1.1rem;font-weight:600;color:#888;cursor:pointer;border-radius:18px;transition:background .2s,color .2s}.tab-btn.active{background:#f8f8f8;color:#111}.tab-content{padding:18px 20px}.timeline{position:relative;margin:0;padding:0 0 0 24px;list-style:none}.timeline:before{content:"";position:absolute;left:10px;top:0;bottom:0;width:2px;background:#ddd;border-radius:2px}.timeline-item{position:relative;margin-bottom:22px;padding-left:16px}.timeline-dot{position:absolute;left:-14px;top:6px;width:14px;height:14px;background:#fff;border-radius:50%;border:2px solid #222;box-shadow:0 0 0 2px #ddd}.timeline-date{font-size:1.02rem;font-weight:600;color:#111}.timeline-duration{font-size:.98rem;color:#555;margin-left:8px}.study-ranking-list{margin:0;padding:0;list-style:none}.ranking-item{display:flex;align-items:center;background:#fafafa;border-radius:12px;margin-bottom:12px;padding:10px 16px;box-shadow:0 1px 4px #00000005;border:1px solid #eee;transition:background .2s;position:relative}.ranking-item.top1,.ranking-item.top2,.ranking-item.top3{background:#f0f0f0;font-weight:700;border:2px solid #111}.ranking-pos{font-size:1.3rem;font-weight:700;width:32px;text-align:center;color:#111}.ranking-name{flex:1;font-size:1.08rem;margin-left:10px;color:#111;font-weight:500}.ranking-value{font-size:1.08rem;font-weight:600;color:#222;margin-left:12px}@media (max-width: 600px){.study-timer-circle{width:120px;height:120px}.study-timer-circle-inner{width:90px;height:90px;font-size:1.1rem}.study-timer-time{font-size:1.3rem}.tabs-container{max-width:98vw}.tab-content{padding:10px 4px 10px 8px}}.study-heatmap{overflow-x:auto;padding-bottom:8px;margin-top:8px;margin-bottom:8px;background:none;border-radius:0;box-shadow:none;display:flex;gap:3px;justify-content:center;padding-top:58px}.study-heatmap-week{display:flex;flex-direction:column;gap:3px}.study-heatmap-day{width:13px;height:13px;border-radius:4px;background:#eee;transition:background .2s;box-shadow:none;border:none;position:relative}.study-heatmap-day[data-level="1"]{background:#bbb}.study-heatmap-day[data-level="2"]{background:#888}.study-heatmap-day[data-level="3"]{background:#444}.study-heatmap-day[data-level="4"]{background:#111}.study-heatmap-tooltip-wrapper{position:relative;display:block;width:100%;height:100%}.study-heatmap-tooltip{display:block;position:absolute;left:50%;bottom:140%;transform:translate(-50%);background:#222;color:#fff;font-size:12px;padding:7px 12px;border-radius:7px;white-space:nowrap;z-index:9999;pointer-events:none;opacity:0;transition:opacity .18s,bottom .18s;box-shadow:0 2px 12px #00000021;font-weight:400;text-align:center;min-width:80px;max-width:180px;word-break:break-word;line-height:1.4;visibility:hidden}.study-heatmap-day:hover .study-heatmap-tooltip,.study-heatmap-day:focus .study-heatmap-tooltip{opacity:1;bottom:160%;pointer-events:auto;visibility:visible}.study-heatmap-tooltip:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border-width:6px 6px 0 6px;border-style:solid;border-color:#222 transparent transparent transparent}.study-heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:10px;font-size:12px;color:#888;justify-content:center}.study-heatmap-legend-box{width:13px;height:13px;border-radius:4px;display:inline-block;margin:0 1px;border:none}.quiz-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px}.quiz-loading-spinner{width:48px;height:48px;border:5px solid #e0e7ef;border-top:5px solid #2563eb;border-radius:50%;animation:quiz-spin 1s linear infinite;margin-bottom:16px}@keyframes quiz-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.quiz-loading-text{font-size:1.1rem;color:#2563eb;font-weight:500;letter-spacing:.02em}.quiz-container{margin:40px auto;background:#fff;border-radius:24px;padding:32px 24px;font-family:SF Pro Display,system-ui,-apple-system,sans-serif!important;position:relative}.quiz-container.no-scroll{overflow:hidden!important;height:100vh!important;touch-action:none!important}.quiz-title{font-size:1.3rem;font-weight:700;color:#2d3142;margin-bottom:8px}.quiz-year{font-size:1rem;color:#6c7a89;margin-bottom:8px}.quiz-streak{font-size:1rem;color:#f59e42;margin-bottom:24px;font-weight:500}.quiz-question{font-size:1.1rem;font-weight:500;margin-bottom:16px}.quiz-context{font-size:.95rem;color:#6c7a89;margin-bottom:16px}.quiz-image{display:block;max-width:100%;margin:16px auto;border-radius:12px;box-shadow:0 2px 8px #2c3e501a}.quiz-alternatives{list-style:none;padding:0;margin:0 0 24px}.quiz-alternatives li{margin-bottom:12px}.quiz-alternatives button{width:100%;padding:14px 18px;border:none;border-radius:12px;background:#f1f3f6;color:#2d3142;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.quiz-alternatives button:hover:enabled{background:#dbeafe}.quiz-alternatives button.alt-correct{background:#22c55e;color:#fff}.quiz-alternatives button.alt-wrong{background:#ef4444;color:#fff}.quiz-feedback{display:flex;flex-direction:column;text-align:center;font-size:.98rem;margin-top:8px;margin-bottom:0;color:#6c7a89;letter-spacing:.01em;animation:fadeIn .3s}.quiz-feedback.acertou{color:#22c55e}.quiz-feedback.errou{color:#ef4444}.quiz-next-btn{margin-top:12px;padding:8px 18px;border:none;border-radius:8px;background:#2d3142;color:#fff;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.quiz-next-btn:hover{background:#475569}.quiz-result{text-align:center;margin-top:32px}.quiz-result h3{font-size:1.3rem;color:#2d3142;margin-bottom:16px}.quiz-result .correct{color:#22c55e}.quiz-result .wrong{color:#ef4444}.quiz-alt-intro{font-size:1rem;color:#2d3142;margin-bottom:16px;font-weight:500}@media (max-width: 450px){.quiz-container{padding:0 3px;margin-top:4px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.quiz-fade-in{animation:quizFadeIn .5s cubic-bezier(.23,1.02,.32,1) both}@keyframes quizFadeIn{0%{opacity:0}to{opacity:1}}.quiz-fade-in-delayed{animation:quizFadeIn .5s cubic-bezier(.23,1.02,.32,1) both;animation-delay:.25s}.quiz-fade-in-more-delayed{animation:quizFadeIn .5s cubic-bezier(.23,1.02,.32,1) both;animation-delay:.45s}.PWABadge-toast{position:fixed;right:0;bottom:0;margin:16px;padding:12px;border:1px solid #8885;border-radius:4px;z-index:1;text-align:left;box-shadow:3px 4px 5px #8885;background-color:#fff}.PWABadge-toast-message{margin-bottom:8px}.PWABadge-toast-button{border:1px solid #8885;outline:none;margin-right:5px;border-radius:2px;padding:3px 10px}
