:root{--bg: #f0f2f5;--card-bg: #ffffff;--border-subtle: #e4e6eb;--text-main: #050505;--text-muted: #65676b;--primary: #1877f2;--primary-dark: #166fe5;--accent: #42b72a}.theme-dark{--bg: #18191a;--card-bg: #242526;--border-subtle: #3a3b3c;--text-main: #e4e6eb;--text-muted: #b0b3b8;--primary: #2d88ff;--primary-dark: #1877f2;--accent: #45bd62}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text-main)}button,input{font-family:inherit}button{cursor:pointer}.app-shell{display:flex;flex-direction:column;min-height:100vh}.nav{height:56px;background:var(--card-bg);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:10;box-shadow:0 2px 4px #0000000a}.nav-left{display:flex;align-items:center;gap:8px}.logo{font-size:24px;font-weight:800;color:var(--primary)}.search-input{background:#f0f2f5;border-radius:999px;border:none;padding:8px 12px;min-width:220px;font-size:14px}.search-input:focus{outline:2px solid var(--primary)}.nav-center{display:flex;gap:4px}.nav-icon-btn{width:110px;height:40px;border-radius:8px;border:none;background:transparent;color:#65676b;font-size:18px}.nav-icon-btn--active{border-bottom:3px solid var(--primary);color:var(--primary)}.nav-right{display:flex;align-items:center;gap:8px}.nav-circle-btn{width:40px;height:40px;border-radius:999px;border:none;background:#e4e6eb;display:flex;align-items:center;justify-content:center}.nav-theme-toggle{background:#f0f2f5}.nav-profile{position:relative;display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px}.nav-profile:hover{background:#f0f2f5}.nav-profile-name{font-size:14px;font-weight:500}.nav-profile-menu{display:none;position:absolute;top:120%;right:0;background:var(--card-bg);border-radius:8px;box-shadow:0 4px 12px #00000026;padding:8px;min-width:160px}.nav-profile:hover .nav-profile-menu{display:flex;flex-direction:column;gap:4px}.nav-profile-menu button,.nav-profile-menu a{border:none;background:transparent;padding:6px 8px;border-radius:6px;text-align:left;font-size:14px;text-decoration:none;color:var(--text-main)}.nav-profile-menu button:hover,.nav-profile-menu a:hover{background:#f0f2f5}.messages-window{position:fixed;bottom:16px;right:16px;width:380px;max-width:calc(100% - 32px);background:var(--card-bg);border-radius:12px;border:1px solid var(--border-subtle);box-shadow:0 8px 24px #00000040;display:flex;flex-direction:column;z-index:50}.messages-window-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px}.messages-window-title{font-size:14px;font-weight:600}.messages-window-close{border:none;background:transparent;font-size:18px;line-height:1}.messages-window-body{display:flex;border-top:1px solid var(--border-subtle);min-height:260px;max-height:360px}.messages-conversations{width:40%;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow-y:auto}.conversation-item{display:flex;align-items:center;gap:6px;padding:6px 8px;border:none;background:transparent;text-align:left}.conversation-item:hover{background:#f0f2f5}.conversation-item--active{background:#1877f21f}.conversation-meta{display:flex;flex-direction:column;gap:2px;font-size:12px}.conversation-name{font-weight:600}.conversation-preview{color:var(--text-muted)}.messages-thread{flex:1;display:flex;flex-direction:column}.messages-thread-header{display:flex;align-items:center;gap:8px;padding:6px 8px;border-bottom:1px solid var(--border-subtle)}.messages-thread-name{font-size:13px;font-weight:600}.messages-thread-subtext{font-size:11px;color:var(--text-muted)}.messages-thread-messages{flex:1;padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.message-row{display:flex}.message-row--me{justify-content:flex-end}.message-bubble{max-width:80%;padding:6px 8px;border-radius:14px;font-size:13px;background:#e4e6eb}.message-row--me .message-bubble{background:var(--primary);color:#fff}.message-text{margin-bottom:2px}.message-time{font-size:10px;color:var(--text-muted)}.messages-thread-empty{padding:12px;font-size:13px;color:var(--text-muted)}.app-main{display:grid;grid-template-columns:1.1fr 2fr 1.1fr;gap:18px;max-width:1200px;margin:16px auto 24px;padding:0 8px}.sidebar,.rightbar{display:flex;flex-direction:column;gap:12px}.sidebar-section,.rightbar-card{background:var(--card-bg);border-radius:8px;padding:12px;border:1px solid var(--border-subtle)}.sidebar-item{width:100%;display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:6px;border:none;background:transparent;font-size:14px;color:var(--text-main)}.sidebar-item:hover{background:#f0f2f5}.sidebar-section h4{font-size:14px;color:var(--text-muted);margin-bottom:6px}.sidebar-reels{margin-top:10px}.sidebar-reels-track{margin-top:6px;height:180px;overflow:hidden}.sidebar-reel-card{border-radius:8px;overflow:hidden;background:#000;position:relative;height:100%}.sidebar-reel-video{width:100%;height:100%;object-fit:cover;display:block}.sidebar-reel-label{position:absolute;left:6px;right:6px;bottom:6px;font-size:12px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.7)}.sidebar-reel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:999px;border:none;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px}.sidebar-reel-arrow--prev{left:6px}.sidebar-reel-arrow--next{right:6px}.sidebar-reel-arrow:disabled{opacity:.4;cursor:default}.rightbar-card h4{font-size:14px;margin-bottom:8px}.contact-item{font-size:14px;padding:4px 0;display:flex;align-items:center;gap:6px;border-radius:6px;padding-inline:6px}.contact-item:hover{background:#f0f2f5}.contact-name{flex:1}.feed{display:flex;flex-direction:column;gap:12px}.composer,.post-card,.rightbar-card,.friends-main,.reels-main{background:var(--card-bg);border-radius:10px;border:1px solid var(--border-subtle);padding:12px}.composer-top{display:flex;gap:8px;align-items:center}.composer-form{flex:1;display:flex;gap:8px}.composer-form input{flex:1;border-radius:999px;border:1px solid var(--border-subtle);padding:8px 12px;background:#f0f2f5}.composer-form button{border-radius:999px;border:none;background:var(--primary);color:#fff;padding:0 16px;font-weight:600}.composer-actions{margin-top:8px;display:flex;justify-content:space-between;font-size:14px;color:var(--text-muted)}.composer-actions button{background:transparent;border:none;padding:4px 8px;border-radius:6px}.composer-actions button:hover{background:#f0f2f5}.composer-media-preview{margin-top:8px;border-radius:10px;border:1px solid var(--border-subtle);padding:8px;display:flex;align-items:center;gap:8px}.composer-media-preview img,.composer-media-preview video{max-height:120px;border-radius:8px}.composer-media-clear{border-radius:999px;border:none;background:#e4e6eb;padding:4px 10px;font-size:12px}.posts-list{display:flex;flex-direction:column;gap:12px}.post-card-header{display:flex;gap:8px}.post-author{font-weight:600;font-size:14px}.post-meta{font-size:12px;color:var(--text-muted)}.post-content{margin-top:8px;font-size:14px}.post-image-wrapper{margin-top:8px;border-radius:10px;overflow:hidden}.post-image{width:100%;display:block}.post-video-wrapper{margin-top:8px;border-radius:10px;overflow:hidden}.post-video{width:100%;display:block;background:#000}.post-stats{margin-top:6px;display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted)}.post-actions{margin-top:8px;display:flex;justify-content:space-between;border-top:1px solid var(--border-subtle);padding-top:6px}.post-actions button{flex:1;border:none;background:transparent;padding:6px 4px;border-radius:6px;font-size:14px}.post-actions button:hover{background:#f0f2f5}.post-like-btn{font-weight:500}.post-like-btn--active{color:var(--primary)}.post-comments{margin-top:8px;border-top:1px solid var(--border-subtle);padding-top:6px}.post-comment-form{display:flex;gap:6px;margin-bottom:6px}.post-comment-form input{flex:1;border-radius:999px;border:1px solid var(--border-subtle);padding:6px 10px;font-size:13px}.post-comment-form button{border-radius:999px;border:none;background:var(--primary);color:#fff;padding:0 12px;font-size:13px;font-weight:600}.post-comments-list{display:flex;flex-direction:column;gap:4px;font-size:13px}.post-comment-item{display:flex;flex-wrap:wrap;gap:4px}.post-comment-text{color:var(--text-main)}.post-comment-time{color:var(--text-muted);font-size:11px}.stories,.reels{background:var(--card-bg);border-radius:10px;border:1px solid var(--border-subtle);padding:10px 12px}.stories-header,.reels-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.stories-create-btn,.reels-create-btn{border-radius:999px;border:none;background:var(--primary);color:#fff;font-size:13px;padding:6px 12px;font-weight:600}.stories-track,.reels-track{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.story-card{min-width:80px;max-width:80px;height:130px;border-radius:12px;background:linear-gradient(135deg,#fbc2eb,#a6c1ee);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-size:13px;text-align:center;padding:8px;cursor:pointer}.story-preview{margin-top:10px;border-radius:10px;overflow:hidden}.story-preview img,.story-preview video{width:100%;display:block}.story-avatar{width:40px;height:40px;border-radius:999px;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:6px}.story-name{word-break:break-word}.reel-card{min-width:110px;max-width:110px;border-radius:10px;overflow:hidden;position:relative;background:#000}.reel-video{width:100%;height:180px;object-fit:cover}.reel-label{position:absolute;left:6px;bottom:6px;right:6px;font-size:12px;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.6)}.reels-main{display:flex;flex-direction:column;gap:12px}.reels-title{font-size:18px}.reels-player{display:flex;flex-direction:column;gap:8px}.reels-video-wrapper{position:relative;border-radius:12px;overflow:hidden;background:#000}.reels-video{width:100%;height:360px;object-fit:cover;display:block}.reels-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:999px;border:none;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}.reels-arrow--prev{left:10px}.reels-arrow--next{right:10px}.reels-arrow:disabled{opacity:.4;cursor:default}.reels-meta{display:flex;flex-direction:column;gap:4px;font-size:14px}.reels-meta h3{font-size:16px}.reels-counter{font-size:12px;color:var(--text-muted)}.reels-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.reels-modal{background:var(--card-bg);border-radius:12px;max-width:960px;width:100%;max-height:90vh;padding:12px 16px 16px;position:relative;display:flex;flex-direction:column}.reels-modal-close{position:absolute;top:8px;right:10px;border:none;background:transparent;font-size:20px}.reels-modal-content{margin-top:12px;display:flex;gap:12px}.reels-modal-meta{flex:.8;display:flex;flex-direction:column;gap:6px;font-size:14px}.reels-modal-meta h3{font-size:16px}.friend-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:90}.friend-modal{background:var(--card-bg);border-radius:12px;max-width:720px;width:100%;max-height:85vh;padding:12px 16px 16px;position:relative;display:flex;flex-direction:column;gap:10px}.friend-modal-close{position:absolute;top:8px;right:10px;border:none;background:transparent;font-size:20px}.friend-modal-header{margin-top:16px}.friend-modal-about{margin-top:4px}.profile-main{max-width:680px;margin:16px auto 32px;display:flex;flex-direction:column;gap:16px}.profile-header-card{background:var(--card-bg);border-radius:8px;box-shadow:0 1px 2px #00000014;border:1px solid var(--border-subtle);overflow:hidden}.profile-cover{height:150px;background:linear-gradient(135deg,#1877f2,#42b72a)}.profile-header-body{display:flex;gap:16px;padding:16px;align-items:center}.profile-avatar-block{display:flex;flex-direction:column;align-items:center;gap:8px}.profile-avatar-large{width:120px;height:120px;border-radius:999px;border:4px solid var(--bg-main);background:#d8dadf;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700;overflow:hidden}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-change-btn{padding:6px 12px;border-radius:999px;border:none;background:var(--primary);color:#fff;font-size:13px;cursor:pointer}.profile-header-text{flex:1}.profile-name{font-size:24px;margin-bottom:4px}.profile-bio{font-size:14px;color:var(--text-muted);margin-bottom:8px}.profile-stats{display:flex;gap:12px;font-size:13px;color:var(--text-muted)}.friend-profile-inline{margin-top:12px;display:flex;flex-direction:column;gap:8px}.friends-main{display:flex;flex-direction:column;gap:10px}.friends-list{max-height:260px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.friends-header{display:flex;align-items:center;justify-content:space-between}.friends-count{font-size:13px;color:var(--text-muted)}.friend-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;border:none;background:transparent;text-align:left}.friend-item:hover{background:#f0f2f5}.friend-meta{display:flex;flex-direction:column;gap:2px}.friend-name{font-size:14px;font-weight:600}.friend-subtext{font-size:12px;color:var(--text-muted)}.profile-actions-row{margin-top:10px;display:flex;gap:8px}.profile-message-btn{padding:6px 16px;border-radius:999px;border:none;background:var(--primary);color:#fff;font-weight:600;font-size:14px}.profile-secondary-btn{padding:6px 16px;border-radius:999px;border:1px solid var(--border-subtle);background:transparent;font-size:14px}.profile-card{background:var(--card-bg);border-radius:8px;box-shadow:0 1px 2px #00000014;border:1px solid var(--border-subtle);padding:12px 16px 14px}.profile-section-title{font-size:16px;margin-bottom:8px}.profile-details{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px;font-size:14px}.profile-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.profile-section-link{border:none;background:transparent;color:var(--primary);font-size:13px;cursor:pointer}.media-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.media-grid-item{border-radius:8px;overflow:hidden}.media-grid-thumb{height:90px;display:flex;align-items:flex-end;padding:6px;color:#fff;font-size:12px}.media-grid-thumb--photo{background:linear-gradient(135deg,#ff9a9e,#fad0c4)}.media-grid-thumb--video{background:linear-gradient(135deg,#4facfe,#00f2fe)}.media-grid-thumb--reel{background:linear-gradient(135deg,#f6d365,#fda085)}.media-grid-icon{margin-right:4px;font-size:13px}.media-grid-label{text-shadow:0 1px 3px rgba(0,0,0,.35)}.avatar{border-radius:999px;background:#d8dadf;display:flex;align-items:center;justify-content:center;font-weight:600}.avatar--small{width:32px;height:32px}.avatar--medium{width:40px;height:40px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:48px;padding:32px 16px}.auth-brand{max-width:360px}.auth-logo{font-size:54px;color:var(--primary);font-weight:800}.auth-tagline{margin-top:8px;font-size:20px}.auth-card{background:var(--card-bg);padding:16px;border-radius:8px;box-shadow:0 8px 24px #0000001a;width:360px}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-form input{padding:12px;border-radius:6px;border:1px solid var(--border-subtle)}.auth-primary-btn{padding:10px;border-radius:6px;border:none;background:var(--primary);color:#fff;font-weight:600;font-size:16px}.auth-primary-btn--full{width:100%}.auth-secondary-btn{display:inline-block;width:100%;text-align:center;padding:10px;border-radius:6px;border:none;background:var(--accent);color:#fff;font-weight:600;font-size:16px;text-decoration:none}.auth-link-btn{border:none;background:transparent;color:var(--primary);font-size:14px}.auth-link-under{display:inline-block;margin-top:8px;font-size:14px;color:var(--primary);text-decoration:none}.auth-link-under:hover{text-decoration:underline}.auth-divider{height:1px;background:var(--border-subtle);margin:6px 0}.auth-error{color:#d93025;font-size:13px}.auth-title{font-size:24px}.auth-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:4px}@media (max-width: 960px){.app-main{grid-template-columns:1fr}.sidebar,.rightbar{display:none}}@media (max-width: 768px){.auth-page{flex-direction:column;align-items:center}.auth-brand{text-align:center}}
