:root{--bg-primary:#08090c;--bg-secondary:#0f1117;--bg-tertiary:#171a24;--accent-cyan:#00f5d4;--accent-cyan-hover:#00d1b5;--accent-purple:#8b5cf6;--accent-purple-glow:#8b5cf626;--accent-cyan-glow:#00f5d41a;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-muted:#9ca3af;--border-color:#1f2937;--danger:#ef4444;--success:#10b981;--font-sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-display:"Outfit", var(--font-sans);font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);justify-content:center;min-height:100vh;display:flex}#root{background-color:var(--bg-primary);border-left:1px solid var(--border-color);border-right:1px solid var(--border-color);flex-direction:column;width:100%;max-width:768px;min-height:100vh;display:flex;position:relative}body.authenticated-body{height:100dvh;overflow:hidden}body.authenticated-body #root{height:100dvh;min-height:0;overflow:hidden}@media (width<=768px){#root{border-left:none;border-right:none;max-width:100%}}.global-loading-screen{background-color:var(--bg-primary);z-index:9999;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.loading-spinner{border:3px solid #00f5d41a;border-top-color:var(--accent-cyan);border-radius:50%;width:40px;height:40px;animation:.8s cubic-bezier(.5,.1,.4,.9) infinite spin;box-shadow:0 0 15px #00f5d426}@keyframes spin{to{transform:rotate(360deg)}}a{color:var(--accent-cyan);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-cyan-hover)}button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;background:0 0;border:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes scaleUp{0%{opacity:0;transform:translate(-50%)scale(.95)}to{opacity:1;transform:translate(-50%)scale(1)}}.no-wasted-space{margin-left:0!important;margin-right:0!important;padding-left:0!important;padding-right:0!important}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.025em;font-weight:700;line-height:1.2}.detail-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#040507d9;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.detail-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);flex-direction:column;width:100%;max-width:460px;animation:.25s cubic-bezier(.16,1,.3,1) scaleUp;display:flex;position:relative}@media (width<=480px){.detail-overlay{align-items:flex-end}.detail-content{border-bottom:none;border-left:none;border-right:none;border-top:2px solid var(--border-color);border-radius:12px 12px 0 0;max-width:100%;animation:.25s cubic-bezier(.16,1,.3,1) slideUp}}.detail-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;display:flex}.detail-title{color:var(--accent-cyan);font-size:1.15rem;font-weight:700}.btn-close-detail{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;display:flex}.btn-close-detail:hover{color:var(--text-primary);background:var(--bg-tertiary)}.detail-body{flex-direction:column;gap:16px;padding:24px 16px;display:flex}.detail-desc{color:var(--text-primary);font-size:.9rem;line-height:1.6}.detail-status-banner{border:1px dashed var(--accent-cyan);color:var(--accent-cyan);background-color:#00f5d414;border-radius:4px;align-items:center;gap:8px;padding:12px;font-size:.8rem;display:flex}.detail-btn-auth{background-color:var(--accent-cyan);color:#08090c;text-align:center;cursor:pointer;border:none;border-radius:4px;margin-top:8px;padding:12px;font-size:.95rem;font-weight:700;transition:background-color .2s}.detail-btn-auth:hover{background-color:var(--accent-cyan-hover)}.landing-container{flex-direction:column;width:100%;min-height:100vh;display:flex}.navbar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:100;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.logo-container{align-items:center;gap:8px;display:flex}.logo-text{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:1.25rem;font-weight:800}.logo-tag{color:var(--accent-cyan);text-transform:uppercase;background-color:#00f5d41a;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.btn-nav-login{color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;background-color:#0000;border-radius:4px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:all .2s}.btn-nav-login:hover{background-color:var(--bg-tertiary);border-color:var(--text-muted)}.hero-sec{text-align:center;border-bottom:1px solid var(--border-color);background:radial-gradient(circle at top,#00f5d414 0%,#0000 70%);padding:40px 16px}.hero-tagline{color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;font-size:.75rem;font-weight:700;display:inline-block}.hero-title{color:var(--text-primary);margin-bottom:12px;font-size:1.75rem;font-weight:800;line-height:1.25}.hero-subtitle{color:var(--text-muted);max-width:440px;margin:0 auto 24px;font-size:.85rem;line-height:1.5}.hero-ctas{flex-direction:column;gap:10px;display:flex}.btn-primary{background-color:var(--accent-cyan);color:#08090c;font-family:var(--font-display);text-align:center;cursor:pointer;border:none;border-radius:4px;padding:12px 24px;font-size:.95rem;font-weight:700;transition:all .2s}.btn-primary:hover{background-color:var(--accent-cyan-hover)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);font-family:var(--font-display);text-align:center;cursor:pointer;border-radius:4px;padding:12px 24px;font-size:.95rem;font-weight:600;transition:all .2s}.btn-secondary:hover{background-color:var(--border-color)}.landing-stats-bar{background-color:var(--border-color);border-bottom:1px solid var(--border-color);grid-template-columns:repeat(2,1fr);gap:1px;display:grid}.landing-stat-item{background-color:var(--bg-primary);text-align:center;padding:16px 8px}.landing-stat-value{font-family:var(--font-display);color:var(--accent-cyan);font-size:1.4rem;font-weight:700}.landing-stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:4px;font-size:.7rem}.feature-grid{background-color:var(--border-color);border-bottom:1px solid var(--border-color);grid-template-columns:repeat(2,1fr);gap:1px;display:grid}.feature-item{background-color:var(--bg-primary);text-align:left;flex-direction:column;align-items:flex-start;padding:20px 16px;transition:background-color .2s;display:flex}.feature-item:hover{background-color:var(--bg-secondary)}.feature-icon-wrapper{color:var(--accent-cyan);justify-content:center;align-items:center;margin-bottom:12px;display:flex}.feature-title{color:var(--text-primary);margin-bottom:6px;font-size:.95rem;font-weight:600}.feature-desc{color:var(--text-muted);font-size:.75rem;line-height:1.35}.user-profile{align-items:center;gap:8px;display:flex}.user-avatar{background-color:var(--accent-cyan);color:#08090c;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:700;display:flex}.btn-logout{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;display:flex}.btn-logout:hover{color:var(--danger);background-color:#ef44441a}.footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);margin-top:auto;padding:24px 16px;font-size:.75rem}.footer-links{justify-content:center;gap:16px;margin-top:8px;display:flex}.footer-link{color:var(--text-muted);text-decoration:none}.footer-link:hover{color:var(--accent-cyan)}.banner-slider-container{aspect-ratio:16/9;background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);width:100%;position:relative;overflow:hidden}.banner-track{width:100%;height:100%;transition:transform .4s cubic-bezier(.25,1,.5,1);display:flex}.banner-slide{min-width:100%;height:100%;position:relative}.banner-image{object-fit:cover;width:100%;height:100%;display:block}.banner-overlay{color:var(--text-primary);background:linear-gradient(#0000 0%,#08090c4d 40%,#08090cf2 100%);flex-direction:column;justify-content:flex-end;height:60%;padding:16px;display:flex;position:absolute;bottom:0;left:0;right:0}.banner-title{text-shadow:0 2px 4px #0009;color:var(--accent-cyan);margin-bottom:4px;font-size:1.1rem;font-weight:700}.banner-desc{color:var(--text-secondary);text-shadow:0 1px 2px #0009;font-size:.75rem;line-height:1.3}.btn-slider-nav{color:var(--text-primary);cursor:pointer;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#08090ca6;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.btn-slider-nav:hover{background-color:var(--accent-cyan);color:#08090c}.btn-slider-nav.prev{left:12px}.btn-slider-nav.next{right:12px}.banner-indicators{z-index:5;gap:6px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.indicator-dot{cursor:pointer;background-color:#fff6;border-radius:50%;width:6px;height:6px;transition:all .2s}.indicator-dot.active{background-color:var(--accent-cyan);border-radius:3px;width:14px}.notice-bar{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap;height:32px;color:var(--accent-cyan);align-items:center;font-size:.8rem;font-weight:500;display:flex;position:relative;overflow:hidden}.notice-bar-prefix{background-color:var(--border-color);color:var(--text-primary);z-index:10;text-transform:uppercase;letter-spacing:.05em;border-right:1px solid var(--border-color);align-items:center;height:100%;padding:0 12px;font-size:.75rem;font-weight:700;display:flex}.notice-track{width:max-content;animation:20s linear infinite marquee;display:flex}.notice-track:hover{animation-play-state:paused}.notice-item{align-items:center;padding-right:50px;display:flex}@keyframes marquee{0%{transform:translate(0,0)}to{transform:translate(-50%)}}.bottom-bar{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:100;justify-content:space-around;align-items:center;width:100%;max-width:500px;height:56px;padding:0 8px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-bar-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;height:100%;padding:4px 0;transition:color .2s;display:flex}.bottom-bar-btn:hover{color:var(--text-primary)}.bottom-bar-btn.active{color:var(--accent-cyan)}.bottom-bar-label{text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;font-weight:600}@media (width>=500px){.sidebar-overlay{width:100%;max-width:500px;left:50%;transform:translate(-50%)}}.sidebar-content{background:linear-gradient(180deg, var(--bg-secondary) 0%, #0c0f14 100%);border-right:1px solid var(--border-color);flex-direction:column;width:300px;height:100%;padding:20px 16px;animation:.3s cubic-bezier(.16,1,.3,1) slideRight;display:flex;position:relative;overflow-y:auto;box-shadow:10px 0 30px #00000080}.sidebar-content::-webkit-scrollbar{width:3px}.sidebar-content::-webkit-scrollbar-track{background:0 0}.sidebar-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:1.5px}.sidebar-title{font-family:var(--font-display);color:var(--accent-cyan);text-shadow:0 0 10px #00f5d433;letter-spacing:.02em;font-size:1.3rem;font-weight:800}.btn-close-sidebar{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;transition:all .2s;display:flex}.btn-close-sidebar:hover{color:var(--text-primary);background-color:var(--bg-tertiary);transform:rotate(90deg)}.sidebar-profile-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0e1a2466;border:1px solid #00f5d41f;border-radius:8px;flex-direction:column;gap:12px;margin-bottom:20px;padding:16px;display:flex;box-shadow:0 4px 12px #0003}.profile-card-top{align-items:center;gap:12px;display:flex}.sidebar-avatar{object-fit:cover;border:2px solid var(--accent-cyan);border-radius:50%;width:46px;height:46px;box-shadow:0 0 10px #00f5d433}.sidebar-avatar-initials{background-color:var(--bg-tertiary);border:2px solid var(--accent-cyan);width:46px;height:46px;font-family:var(--font-display);color:var(--accent-cyan);border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 0 10px #00f5d433}.profile-details{flex-direction:column;flex:1;display:flex;overflow:hidden}.profile-name-row{align-items:center;gap:4px;display:flex}.profile-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.verified-badge-icon{color:var(--accent-cyan);flex-shrink:0}.profile-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.profile-badge{background-color:#00f5d40f;border:1px solid #00f5d433;border-radius:12px;align-self:flex-start;padding:4px 8px}.badge-text{color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;font-weight:700}.sidebar-stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;display:grid}.sidebar-stat-item{border:1px solid var(--border-color);background-color:#ffffff05;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:10px 8px;transition:background-color .2s;display:flex}.sidebar-stat-item:hover{background-color:#00f5d405;border-color:#00f5d426}.stat-value{font-family:var(--font-display);color:var(--text-primary);font-size:1.15rem;font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:center;font-size:.62rem;font-weight:600}.menu-section-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 6px 4px;font-size:.7rem;font-weight:700}.sidebar-menu-item{color:var(--text-secondary);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex;position:relative}.sidebar-menu-item:hover{color:var(--accent-cyan);background-color:#00f5d40a;padding-left:16px}.sidebar-menu-item svg{transition:transform .2s}.sidebar-menu-item:hover svg{color:var(--accent-cyan);transform:scale(1.1)}.sidebar-version-section{border:1px solid var(--border-color);background-color:#00000026;border-radius:6px;margin-top:16px;overflow:hidden}.btn-version-accordion{cursor:pointer;width:100%;color:var(--text-muted);background:0 0;border:none;justify-content:space-between;align-items:center;padding:10px 12px;transition:background-color .2s,color .2s;display:flex}.btn-version-accordion:hover{color:var(--text-primary);background-color:#ffffff05}.version-tag{font-size:.72rem;font-weight:700;font-family:var(--font-display)}.version-changelog{border-top:1px solid var(--border-color);background-color:#00000040;flex-direction:column;gap:10px;padding:8px 12px;animation:.2s ease-out slideDown;display:flex}.changelog-item{flex-direction:column;gap:2px;display:flex}.changelog-version{color:var(--accent-cyan);font-size:.65rem;font-weight:700}.changelog-desc{color:var(--text-muted);white-space:pre-line;font-size:.62rem;line-height:1.35}.sidebar-footer{flex-direction:column;align-items:center;gap:6px;margin-top:auto;padding-top:24px;display:flex}.footer-line{background-color:var(--border-color);border-radius:1px;width:40px;height:2px;margin-bottom:8px}.made-by-text{color:var(--text-muted);font-size:.7rem;font-weight:600}.rifat-link{color:var(--accent-cyan);font-weight:700;text-decoration:none;transition:color .2s,text-shadow .2s;position:relative}.rifat-link:hover{color:var(--accent-cyan-hover);text-shadow:0 0 8px #00f5d466}.copyright-sub{color:var(--text-muted);opacity:.6;font-size:.6rem}@keyframes slideRight{0%{transform:translate(-100%)}to{transform:translate(0,0)}}.home-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.home-main-scrollable{flex-direction:column;flex:1;padding-bottom:80px;display:flex;overflow-y:auto}.home-main-scrollable::-webkit-scrollbar{width:4px}.home-main-scrollable::-webkit-scrollbar-track{background:0 0}.home-main-scrollable::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.home-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:90;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.home-logo{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:1.25rem;font-weight:800}.btn-hamburger{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;display:flex}.btn-hamburger:hover{background-color:var(--bg-tertiary)}.sidebar-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#040507d9;justify-content:flex-start;width:100vw;height:100vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}@media (width>=500px){.sidebar-overlay{width:100%;max-width:500px;left:50%;transform:translate(-50%)}}.sidebar-content{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;width:280px;height:100%;padding:20px 16px;animation:.25s cubic-bezier(.16,1,.3,1) slideRight;display:flex;position:relative}.sidebar-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;display:flex}.sidebar-title{font-family:var(--font-display);color:var(--accent-cyan);font-size:1.2rem;font-weight:800}.btn-close-sidebar{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.btn-close-sidebar:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.sidebar-user-section{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;flex-direction:column;gap:8px;margin-bottom:24px;padding:12px;display:flex}.sidebar-user-email{color:var(--text-secondary);word-break:break-all;font-size:.8rem}.sidebar-menu-list{flex-direction:column;gap:8px;display:flex}.sidebar-menu-item{color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:.9rem;font-weight:600;transition:all .2s;display:flex}.sidebar-menu-item:hover{background-color:var(--bg-tertiary);border-color:var(--border-color);color:var(--accent-cyan)}.sidebar-menu-item.danger:hover{color:var(--danger);background-color:#ef44440d;border-color:#ef444433}.feed-content{text-align:left;flex-direction:column;gap:16px;padding:24px 16px;display:flex}.feed-title{color:var(--text-primary);font-size:1.25rem;font-weight:700}.feed-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:16px}.feed-card-title{color:var(--accent-cyan);margin-bottom:8px;font-size:.95rem;font-weight:600}.feed-card-text{color:var(--text-muted);font-size:.8rem;line-height:1.45}.courses-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.courses-main{background-color:var(--bg-primary);flex-direction:column;flex:1;display:flex;overflow:hidden}.tech-grid{background-color:var(--border-color);grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:1px;width:100%;height:100%;display:grid}.tech-btn{background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;text-align:left;border:none;outline:none;flex-direction:column;justify-content:space-between;align-items:stretch;padding:16px;text-decoration:none;transition:all .2s;display:flex}.tech-btn:hover{background-color:var(--bg-secondary)}.tech-card-header{align-items:center;gap:8px;display:flex}.tech-icon{color:var(--accent-cyan);flex-shrink:0;transition:transform .2s}.tech-btn:hover .tech-icon{color:var(--accent-cyan-hover);transform:scale(1.1)}.tech-name{font-family:var(--font-display);letter-spacing:-.01em;color:var(--text-primary);font-size:.95rem;font-weight:800}.tech-btn:hover .tech-name{color:var(--accent-cyan)}.tech-desc{color:var(--text-muted);flex-grow:1;margin:8px 0;font-size:.7rem;line-height:1.35}.tech-stats-row{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.tech-badge{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:3px;padding:2px 6px;font-size:.6rem;font-weight:700}.tech-badge.cyan{color:var(--accent-cyan);border-color:#00f5d433}.semesters-view{background-color:var(--bg-primary);flex-direction:column;width:100%;height:100%;padding:12px;display:flex}.semesters-header{align-items:center;margin-bottom:12px;display:flex}.semesters-title{color:var(--text-primary);border-left:3px solid var(--accent-cyan);padding-left:8px;font-size:1.05rem;font-weight:800}.semesters-grid{flex:1;grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(2,1fr);gap:8px;width:100%;display:grid}.semester-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;text-align:center;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:10px;transition:all .2s;display:flex}.semester-card:hover{background-color:var(--bg-tertiary);border-color:var(--accent-cyan)}.semester-card:hover .semester-num{color:var(--accent-cyan);transform:scale(1.08)}.semester-num{font-family:var(--font-display);color:var(--text-secondary);margin-bottom:2px;font-size:1.4rem;font-weight:800;transition:transform .2s,color .2s}.semester-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.65rem;font-weight:700}.semester-card:nth-child(7){grid-column:span 2}.account-container{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.account-main{background-color:var(--bg-primary);flex-direction:column;flex:1;justify-content:flex-start;align-items:center;gap:24px;padding:24px 16px 80px;display:flex;overflow-y:auto}.account-main::-webkit-scrollbar{width:4px}.account-main::-webkit-scrollbar-track{background:0 0}.account-main::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.avatar-section{flex-direction:column;align-items:center;margin-top:8px;display:flex;position:relative}.account-avatar{background-color:var(--bg-tertiary);border:2px solid var(--accent-cyan);width:90px;height:90px;font-family:var(--font-display);color:var(--accent-cyan);object-fit:cover;border-radius:50%;justify-content:center;align-items:center;font-size:2.2rem;font-weight:800;display:flex;box-shadow:0 0 20px #00f5d426}.btn-avatar-edit-trigger{background-color:var(--accent-cyan);color:#08090c;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .2s;display:flex;position:absolute;bottom:0;right:0;box-shadow:0 2px 8px #0006}.btn-avatar-edit-trigger:hover{background-color:var(--accent-cyan-hover);transform:scale(1.1)}.username-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;flex-direction:column;gap:12px;width:100%;padding:16px;display:flex}.username-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.username-input-row{gap:8px;width:100%;display:flex}.username-field{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;outline:none;flex:1;padding:10px 12px;font-size:.9rem;font-weight:600;transition:border-color .2s}.username-field:focus{border-color:var(--accent-cyan)}.btn-save-username{background-color:var(--accent-cyan);color:#08090c;font-family:var(--font-display);cursor:pointer;border:none;border-radius:4px;padding:0 16px;font-size:.85rem;font-weight:700;transition:background-color .2s}.btn-save-username:hover{background-color:var(--accent-cyan-hover)}.info-section{flex-direction:column;gap:8px;width:100%;display:flex}.info-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.info-value{color:var(--text-primary);word-break:break-all;font-size:.85rem;font-weight:700}.avatar-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#040507d9;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s fadeIn;display:flex;position:fixed;top:0;left:0}@media (width<=480px){.avatar-modal-overlay{align-items:flex-end}}.avatar-modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;flex-direction:column;width:100%;max-width:400px;animation:.2s scaleUp;display:flex}@media (width<=480px){.avatar-modal-content{border-bottom:none;border-left:none;border-right:none;border-top:2px solid var(--border-color);border-radius:12px 12px 0 0;max-width:100%;animation:.25s slideUp}}.avatar-modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;display:flex}.avatar-modal-title{color:var(--accent-cyan);font-size:1.1rem;font-weight:700}.btn-close-avatar-modal{color:var(--text-muted);cursor:pointer;background:0 0;border:none}.btn-close-avatar-modal:hover{color:var(--text-primary)}.avatar-modal-body{flex-direction:column;gap:16px;padding:20px 16px;display:flex}.avatar-modal-preview-container{justify-content:center;align-items:center;width:100%;padding:16px 0;display:flex}.avatar-modal-preview-img{border:3px solid var(--accent-cyan);object-fit:cover;border-radius:50%;width:120px;height:120px;box-shadow:0 0 24px #00f5d440}.btn-upload-trigger-large{background-color:var(--bg-primary);color:var(--text-primary);border:1px dashed var(--border-color);cursor:pointer;text-align:center;border-radius:4px;justify-content:center;align-items:center;gap:10px;width:100%;padding:16px;font-size:.9rem;font-weight:700;transition:all .2s;display:flex}.btn-upload-trigger-large:hover:not(.disabled){border-color:var(--accent-cyan);color:var(--accent-cyan);background-color:#00f5d40a}.btn-upload-trigger-large.disabled{opacity:.6;cursor:not-allowed}.avatar-modal-btn-save{background-color:var(--accent-cyan);color:#08090c;text-align:center;cursor:pointer;font-weight:700;font-family:var(--font-display);border:none;border-radius:4px;padding:12px}.avatar-modal-btn-save:hover{background-color:var(--accent-cyan-hover)}@media (width<=480px){.avatar-modal-content{max-height:85vh}.avatar-modal-body{padding-bottom:32px;overflow-y:auto}}.chat-container{background-color:var(--bg-primary);flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.chat-main{background-color:var(--bg-primary);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.chat-feed{scroll-behavior:smooth;background:radial-gradient(circle at 100% 0,#00f5d408,#0000 40%),radial-gradient(circle at 0 100%,#00f5d403,#0000 30%);flex-direction:column;flex:1;gap:12px;padding:16px 12px;display:flex;overflow-y:auto}.chat-feed::-webkit-scrollbar{width:4px}.chat-feed::-webkit-scrollbar-track{background:0 0}.chat-feed::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.msg-wrapper{-webkit-user-select:none;user-select:none;flex-direction:column;max-width:80%;transition:transform .2s;display:flex;position:relative}.msg-wrapper.self{align-self:flex-end}.msg-wrapper.other{align-self:flex-start}.swipe-indicator{color:var(--accent-cyan);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;position:absolute;top:50%;left:-32px;transform:translateY(-50%)}.msg-wrapper.swiping-right .swipe-indicator{opacity:1;transform:translateY(-50%)scale(1.1)}.msg-meta{align-items:center;gap:6px;margin-bottom:3px;padding:0 4px;display:flex}.msg-wrapper.self .msg-meta{flex-direction:row-reverse}.msg-avatar{object-fit:cover;border:1px solid var(--border-color);background-color:var(--bg-tertiary);width:20px;height:20px;color:var(--accent-cyan);border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;font-weight:800;display:flex}.msg-sender-name{color:var(--text-secondary);font-size:.72rem;font-weight:700}.msg-timestamp{color:var(--text-muted);font-size:.6rem}.msg-reply-ref{border-left:2.5px solid var(--accent-cyan);color:var(--text-muted);background-color:#0003;border-radius:3px 3px 0 0;flex-direction:column;gap:1px;margin-bottom:2px;padding:4px 8px;font-size:.68rem;display:flex}.msg-reply-ref-name{color:var(--accent-cyan);font-size:.62rem;font-weight:700}.msg-card{color:var(--text-primary);word-break:break-word;border-radius:6px;flex-direction:column;padding:8px 12px;font-size:.82rem;line-height:1.4;display:flex;position:relative;box-shadow:0 1px 2px #0000001a}.msg-wrapper.self .msg-card{background-color:#0e1a24;border:1px solid #00f5d426;border-radius:8px 0 8px 8px}.msg-wrapper.other .msg-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:0 8px 8px}.msg-deleted{color:var(--text-muted);font-size:.75rem;font-style:italic}.msg-actions-overlay{background-color:var(--bg-tertiary);border:1px solid var(--border-color);opacity:0;z-index:10;border-radius:12px;gap:4px;padding:2px 6px;transition:opacity .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.msg-wrapper.self .msg-actions-overlay{left:-54px}.msg-wrapper.other .msg-actions-overlay{right:-54px}.msg-wrapper:hover .msg-actions-overlay{opacity:1}.btn-msg-action{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:2px;transition:color .15s,background-color .15s;display:flex}.btn-msg-action:hover{color:var(--text-primary);background-color:#ffffff0d}.btn-msg-action.danger:hover{color:#ff5e5e}.reply-preview-bar{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);border-left:3px solid var(--accent-cyan);justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;animation:.18s slideUp;display:flex}.reply-preview-info{flex-direction:column;gap:2px;display:flex;overflow:hidden}.reply-preview-label{color:var(--accent-cyan);text-transform:uppercase;letter-spacing:.02em;font-size:.65rem;font-weight:700}.reply-preview-text{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.btn-close-reply{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:color .15s;display:flex}.btn-close-reply:hover{color:var(--text-primary)}.chat-input-form{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);align-items:center;gap:10px;padding:10px 12px;display:flex}.chat-input-field{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:20px;outline:none;flex:1;padding:10px 14px;font-size:.85rem;font-weight:600;transition:border-color .2s}.chat-input-field:focus{border-color:#00f5d466}.btn-chat-send{background-color:var(--accent-cyan);color:#08090c;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background-color .15s,transform .1s;display:flex}.btn-chat-send:hover{background-color:var(--accent-cyan-hover);transform:scale(1.05)}.btn-chat-send:active{transform:scale(.95)}@media (width<=480px){.msg-wrapper{max-width:88%}.msg-actions-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0e1a24f2}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#040507d9;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);flex-direction:column;width:100%;max-width:420px;animation:.25s cubic-bezier(.16,1,.3,1) scaleUp;display:flex;position:relative}@media (width<=480px){.modal-overlay{align-items:flex-end}.modal-content{border-bottom:none;border-left:none;border-right:none;border-top:2px solid var(--border-color);border-radius:12px 12px 0 0;max-width:100%;max-height:85vh;animation:.25s cubic-bezier(.16,1,.3,1) slideUp}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px;display:flex}.modal-title{font-size:1.2rem;font-weight:700}.btn-close-modal{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.btn-close-modal:hover{color:var(--text-primary);background:var(--bg-tertiary)}.modal-body{flex-direction:column;gap:16px;padding:20px 16px;display:flex;overflow-y:auto}.auth-form{flex-direction:column;gap:12px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.form-input{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;outline:none;padding:10px 12px;font-size:.9rem;transition:border-color .2s}.form-input:focus{border-color:var(--accent-cyan)}.btn-auth-submit{background-color:var(--accent-cyan);color:#08090c;font-family:var(--font-display);text-align:center;cursor:pointer;border:none;border-radius:4px;margin-top:4px;padding:12px;font-size:.95rem;font-weight:700;transition:background-color .2s}.btn-auth-submit:hover{background-color:var(--accent-cyan-hover)}.auth-divider{text-align:center;color:var(--text-muted);align-items:center;margin:4px 0;font-size:.75rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid var(--border-color);flex:1}.auth-divider:not(:empty):before{margin-right:.5em}.auth-divider:not(:empty):after{margin-left:.5em}.btn-google-auth{color:#1f2937;cursor:pointer;background-color:#fff;border:none;border-radius:4px;justify-content:center;align-items:center;gap:10px;width:100%;padding:10px;font-size:.9rem;font-weight:600;transition:background-color .2s;display:flex}.btn-google-auth:hover{background-color:#e5e7eb}.btn-guest-auth{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;gap:10px;width:100%;padding:10px;font-size:.9rem;font-weight:600;transition:background-color .2s,color .2s;display:flex}.btn-guest-auth:hover{background-color:var(--border-color);color:var(--accent-cyan)}.google-icon{width:18px;height:18px}.auth-switch{text-align:center;color:var(--text-muted);margin-top:8px;font-size:.8rem}.auth-switch-btn{color:var(--accent-cyan);cursor:pointer;background:0 0;border:none;margin-left:4px;font-weight:600}.auth-switch-btn:hover{text-decoration:underline}.auth-error{color:var(--danger);text-align:left;background-color:#ef44441a;border:1px solid #ef444433;border-radius:4px;padding:8px 12px;font-size:.8rem}.toast-msg{background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-left:4px solid var(--accent-cyan);color:var(--text-primary);z-index:2000;white-space:nowrap;border-radius:4px;padding:12px 20px;font-size:.85rem;font-weight:600;animation:.2s scaleUp;position:fixed;bottom:72px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000080}#root{max-width:500px}
