:root{--app-bg:#eef2f6;--window-bg:#fff;--sidebar-bg:transparent;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--accent:#4f46e5;--accent-hover:#4338ca;--bento-bg:#fff;--bento-border:#0f172a1a;--danger:#e11d48;--success:#059669;--warning:#ea580c;--info:#2563eb;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 2px #0f172a0f;--shadow-bento:0 4px 6px -1px #0f172a0d, 0 2px 4px -2px #0f172a0d, 0 0 0 1px var(--bento-border);--shadow-float:0 20px 25px -5px #0f172a1a, 0 8px 10px -6px #0f172a1a, 0 0 0 1px var(--bento-border);--transition:.25s cubic-bezier(.25, 1, .5, 1)}[data-theme=dark]{--app-bg:#09090b;--window-bg:#141417;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--accent:#6366f1;--accent-hover:#818cf8;--bento-bg:#1e1e22;--bento-border:#ffffff1f;--shadow-bento:0 4px 6px -1px #00000080, 0 0 0 1px var(--bento-border);--shadow-float:0 25px 30px -5px #000000b3, 0 0 0 1px var(--bento-border)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--app-bg);color:var(--text-primary);height:100vh;transition:background-color var(--transition);font-family:Inter,sans-serif;display:flex;overflow:hidden}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-family:Outfit,sans-serif;font-weight:600}ul{list-style:none}a{color:inherit;text-decoration:none}button,input{background:0 0;border:none;outline:none;font-family:inherit}.os-container{gap:.5rem;width:100vw;height:100vh;padding:.5rem;display:flex}.os-sidebar{z-index:100;flex-direction:column;width:260px;padding:1rem .5rem;transition:transform .3s;display:flex}.sidebar-header{padding:0 1rem 1.5rem}.student-profile{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.profile-img{border-radius:var(--radius-sm);border:1px solid var(--bento-border);width:44px;height:44px}.profile-text{flex:1;min-width:0}.profile-text h3{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.1rem;font-size:1rem;overflow:hidden}.profile-text p{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.semester-chips{scrollbar-width:none;gap:.4rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.semester-chips::-webkit-scrollbar{display:none}.chip{border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;padding:.3rem .8rem;font-size:.75rem;font-weight:600}.chip:hover{color:var(--text-primary);background:#7373731a}.chip.active{background:var(--text-primary);color:var(--app-bg)}.os-nav{scrollbar-width:thin;scrollbar-color:var(--bento-border) transparent;flex:1;padding:0 .5rem;overflow-y:auto}.os-nav::-webkit-scrollbar{width:4px}.os-nav::-webkit-scrollbar-track{background:0 0}.os-nav::-webkit-scrollbar-thumb{background:var(--bento-border);border-radius:var(--radius-full)}.os-nav::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.nav-section{margin-bottom:2rem}.nav-section h4{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 .5rem .5rem;font-size:.7rem}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:var(--transition);align-items:center;margin-bottom:.2rem;padding:.5rem;font-size:.9rem;font-weight:500;display:flex;position:relative}.nav-item i{text-align:center;width:24px;margin-right:.75rem;font-size:1.2rem}.nav-item:hover{color:var(--text-primary);background:#7373731a}.nav-item.active{color:var(--text-primary);background:#73737326;font-weight:600}.nav-item .badge{background:var(--accent);color:#fff;border-radius:var(--radius-full);margin-left:auto;padding:.1rem .4rem;font-size:.7rem}.nav-item.external .external-icon{color:var(--text-muted);margin-left:auto;margin-right:0;font-size:.9rem}.sidebar-footer{border-top:1px solid var(--bento-border);padding:1rem}.integrations{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.integration-pill{border-radius:var(--radius-full);align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.75rem;font-weight:500;display:flex}.integration-pill.success{color:var(--success);background:#10b9811a}.integration-pill.warning{color:var(--warning);background:#f59e0b1a}.footer-actions{gap:.5rem;display:flex}.icon-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;display:flex}.icon-btn:hover{color:var(--text-primary);background:#7373731a}.app-window{background-color:var(--window-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);border:1px solid var(--bento-border);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.app-header{border-bottom:1px solid var(--bento-border);-webkit-backdrop-filter:blur(10px);justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex}.breadcrumb{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.breadcrumb i{font-size:1.1rem}.breadcrumb .current{color:var(--text-primary);font-weight:500}.breadcrumb .separator{color:var(--text-muted)}.omni-search{background:var(--window-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);width:320px;transition:var(--transition);box-shadow:inset 0 2px 4px #00000005, var(--shadow-sm);align-items:center;padding:.5rem .8rem;display:flex}.omni-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126,inset 0 2px 4px #00000005}.omni-search i{color:var(--text-secondary);margin-right:.5rem;font-size:1.2rem;font-weight:700}.omni-search input{color:var(--text-primary);flex:1;font-size:.9rem;font-weight:500}.omni-search input::placeholder{color:var(--text-muted);font-weight:400}.omni-search .shortcut{color:var(--text-secondary);background:var(--app-bg);border:1px solid var(--bento-border);border-radius:4px;padding:.2rem .4rem;font-size:.75rem;font-weight:600}.app-content-scroll{flex:1;padding:2rem;overflow-y:auto}.views-wrapper{max-width:1200px;margin:0 auto}.view{animation:.4s cubic-bezier(.16,1,.3,1) forwards slideUp;display:none}.view.active{display:block}@keyframes slideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.dashboard-hero{justify-content:space-between;align-items:flex-end;margin-bottom:2rem;display:flex}.hero-text h1{margin-bottom:.2rem;font-size:2rem}.hero-text p{color:var(--text-secondary);font-size:.95rem}.date-badge{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);width:80px;box-shadow:var(--shadow-sm);flex-direction:column;justify-content:center;align-items:center;padding:.5rem 1.2rem;display:flex}.date-badge .day{color:var(--danger);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:700}.date-badge .num{margin:.2rem 0;font-family:Outfit;font-size:1.8rem;font-weight:700;line-height:1}.date-badge .month{color:var(--text-secondary);font-size:.75rem;font-weight:500}.bento-layout{grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(100px,auto);gap:1.25rem;display:grid}.grid-col-span-2{grid-column:span 2}.grid-col-span-3{grid-column:span 3}.grid-row-span-2{grid-row:span 2}.bento-box{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-bento);transition:var(--transition);flex-direction:column;padding:1.5rem;display:flex}.bento-box:hover{box-shadow:var(--shadow-float)}.box-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.box-header h3{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1rem;font-weight:600;display:flex}.box-header h3 i{color:var(--text-secondary);font-size:1.3rem}.live-class-box{background:linear-gradient(135deg,#6366f10d,#0000);border-color:#6366f133}.pulse-indicator{color:var(--accent);align-items:center;gap:.4rem;font-size:.75rem;font-weight:600;display:flex}.pulse-indicator:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #6366f1b3}70%{transform:scale(1);box-shadow:0 0 0 6px #6366f100}to{transform:scale(.95);box-shadow:0 0 #6366f100}}.class-details h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.3rem}.class-meta{flex-direction:column;gap:.4rem;margin-bottom:1.5rem;display:flex}.meta-item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.meta-item i{font-size:1.1rem}.progress-track{border-radius:var(--radius-full);background:#6366f11a;height:6px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:var(--accent);border-radius:var(--radius-full);height:100%;transition:width 1s}.time-range{color:var(--accent);text-align:right;font-size:.75rem;font-weight:600}.btn-icon-small{border:1px solid var(--bento-border);cursor:pointer;width:24px;height:24px;color:var(--text-secondary);transition:var(--transition);border-radius:4px;justify-content:center;align-items:center;display:flex}.btn-icon-small:hover{background:var(--text-primary);color:var(--window-bg)}.task-list{flex-direction:column;gap:.75rem;display:flex}.task-item{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:1px solid #0000;align-items:flex-start;gap:.75rem;padding:.5rem;display:flex}.task-item:hover{background:var(--window-bg);border-color:var(--bento-border)}.task-item input{display:none}.custom-checkbox{border:2px solid var(--text-muted);width:18px;height:18px;transition:var(--transition);border-radius:4px;margin-top:.1rem;position:relative}.task-item input:checked+.custom-checkbox{background:var(--text-primary);border-color:var(--text-primary)}.task-item input:checked+.custom-checkbox:after{content:"";border:solid var(--window-bg);border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:2px;left:5px;transform:rotate(45deg)}.task-info{flex-direction:column;gap:.1rem;display:flex}.task-info .title{color:var(--text-primary);transition:var(--transition);font-size:.9rem;font-weight:500}.task-info .due{color:var(--text-secondary);font-size:.75rem}.task-item.urgent .due{color:var(--danger);font-weight:500}.task-item.completed .title{color:var(--text-muted);text-decoration:line-through}.timeline{flex-direction:column;padding-left:1rem;display:flex;position:relative}.timeline:before{content:"";background:var(--bento-border);width:1px;position:absolute;top:0;bottom:0;left:1rem}.timeline-item{margin-bottom:1.5rem;padding-left:2rem;position:relative}.timeline-item:last-child{margin-bottom:0}.tl-icon{color:#fff;width:28px;height:28px;box-shadow:0 0 0 4px var(--bento-bg);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:0;left:-14px}.bg-blue{background:#3b82f6}.bg-red{background:#ef4444}.bg-green{background:#10b981}.bg-purple{background:#a855f7}.tl-time{color:var(--text-muted);margin-bottom:.2rem;font-size:.7rem;font-weight:600;display:block}.tl-content h4{margin-bottom:.2rem;font-size:.95rem}.tl-content p{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.heatmap-box{flex-direction:column;justify-content:space-between}.overall-stat{color:var(--success);border-radius:var(--radius-full);background:#10b9811a;padding:.2rem .6rem;font-size:.85rem;font-weight:600}.heatmap-container{scrollbar-width:thin;grid-template-rows:repeat(5,1fr);grid-auto-flow:column;gap:4px;margin-bottom:1rem;padding-bottom:.5rem;display:grid;overflow-x:auto}.heatmap-container .cell{border-radius:2px;width:12px;height:12px}.level-0{background:var(--bento-border)}[data-theme=dark] .level-1{background:#1e3a8a}[data-theme=dark] .level-2{background:#1d4ed8}[data-theme=dark] .level-3{background:#3b82f6}[data-theme=dark] .level-4{background:#60a5fa}[data-theme=light] .level-1{background:#dbeafe}[data-theme=light] .level-2{background:#93c5fd}[data-theme=light] .level-3{background:#3b82f6}[data-theme=light] .level-4{background:#1d4ed8}.heatmap-legend{color:var(--text-muted);justify-content:flex-end;align-items:center;gap:.5rem;font-size:.75rem;display:flex}.legend-scale{gap:2px;display:flex}.legend-scale .cell{border-radius:2px;width:10px;height:10px}.carousel-controls{gap:.4rem;display:flex}.carousel-controls button{border:1px solid var(--bento-border);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.carousel-controls button:hover{background:var(--text-primary);color:var(--window-bg)}.events-carousel{scroll-behavior:smooth;scroll-snap-type:x mandatory;scrollbar-width:none;gap:1rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.events-carousel::-webkit-scrollbar{display:none}.event-card{border-radius:var(--radius-md);border:1px solid var(--bento-border);scroll-snap-align:start;background:var(--window-bg);min-width:240px;transition:var(--transition);cursor:pointer;flex-direction:column;display:flex;overflow:hidden}.event-card:hover{box-shadow:var(--shadow-bento);border-color:var(--accent);transform:translateY(-4px)}.event-img{background-position:50%;background-size:cover;width:100%;height:100px}.event-img.tech{background-image:linear-gradient(135deg,#1e1b4b,#4338ca)}.event-img.cultural{background-image:linear-gradient(135deg,#4a044e,#c026d3)}.event-img.workshop{background-image:linear-gradient(135deg,#064e3b,#059669)}.event-img.sports{background-image:linear-gradient(135deg,#7c2d12,#ea580c)}.event-info{flex-direction:column;gap:.4rem;padding:1rem;display:flex}.event-tag{text-transform:uppercase;color:var(--text-secondary);font-size:.7rem;font-weight:600}.event-info h4{font-size:1.05rem}.event-info p{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.8rem;display:flex}.d-mobile{display:none}.mobile-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;opacity:0;pointer-events:none;transition:var(--transition);background:#00000080;position:fixed;inset:0}@media (width<=1024px){.bento-layout{grid-template-columns:repeat(2,1fr)}.feed-box{grid-area:auto/span 2}.events-box{grid-column:span 2}}@media (width<=768px){.os-container{padding:0}.app-window{border:none;border-radius:0}.d-mobile{cursor:pointer;width:36px;height:36px;color:var(--text-primary);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.os-sidebar{background:var(--window-bg);box-shadow:var(--shadow-float);z-index:100;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.os-sidebar.open{transform:translate(0)}.mobile-overlay.active{opacity:1;pointer-events:auto}.bento-layout{grid-template-columns:1fr}.grid-col-span-2,.grid-col-span-3,.feed-box{grid-column:1}.dashboard-hero{flex-direction:column;align-items:flex-start;gap:1rem}.date-badge{align-self:flex-start}.omni-search{display:none}}.landing-body{height:auto;display:block;overflow-y:auto}.landing-nav{z-index:1000;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--bento-border);background:rgba(var(--app-bg-rgb), .7);justify-content:space-between;align-items:center;padding:1.5rem 4rem;display:flex;position:sticky;top:0}[data-theme=dark]{--app-bg-rgb:9, 9, 11;--window-bg-rgb:20, 20, 23;--bento-bg-rgb:30, 30, 34}[data-theme=light]{--app-bg-rgb:238, 242, 246;--window-bg-rgb:255, 255, 255;--bento-bg-rgb:255, 255, 255}[data-theme=dark] .landing-nav{background:#09090bcc}[data-theme=light] .landing-nav{background:#e2e4e9cc}.landing-logo{color:var(--text-primary);align-items:center;gap:.5rem;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;display:flex}.landing-logo i{color:var(--accent);font-size:1.8rem}.nav-actions{align-items:center;gap:1.5rem;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-full);transition:var(--transition);align-items:center;gap:.5rem;padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.btn-outline{color:var(--text-primary);border-radius:var(--radius-full);border:1px solid var(--bento-border);transition:var(--transition);background:0 0;padding:.6rem 1.5rem;font-size:.95rem;font-weight:600}.btn-outline:hover{background:var(--bento-bg)}.btn-large{padding:1rem 2rem!important;font-size:1.1rem!important}.hero-section{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:80vh;padding:4rem 2rem;display:flex;position:relative;overflow:hidden}.hero-glow{z-index:-1;filter:blur(40px);background:radial-gradient(circle,#6366f126 0%,#6366f100 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hero-badge{border-radius:var(--radius-full);color:var(--accent);background:#6366f11a;border:1px solid #6366f133;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.4rem 1rem;font-size:.85rem;font-weight:600;animation:.6s ease-out slideUp;display:inline-flex}.hero-title{background:linear-gradient(to right, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;max-width:900px;margin-bottom:1.5rem;font-family:Outfit,sans-serif;font-size:4.5rem;font-weight:700;line-height:1.1;animation:.8s ease-out slideUp}.hero-subtitle{color:var(--text-secondary);max-width:600px;margin-bottom:2.5rem;font-size:1.25rem;line-height:1.6;animation:1s ease-out slideUp}.hero-cta{z-index:10;gap:1rem;animation:1.2s ease-out slideUp;display:flex;position:relative}.typing-container{color:var(--text-secondary);white-space:nowrap;justify-content:center;align-items:center;height:2.5rem;margin-bottom:2rem;font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:500;animation:.9s ease-out slideUp;display:flex;overflow:hidden}.typing-prefix{color:var(--text-primary);margin-right:.35em}.typing-text{color:var(--accent);font-weight:600}.typing-cursor{background-color:var(--accent);vertical-align:middle;width:3px;height:1.2em;margin-left:4px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.floating-cards-container{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.float-card{background:rgba(var(--window-bg-rgb), .4);-webkit-backdrop-filter:blur(12px);border:1px solid var(--bento-border);border-radius:var(--radius-lg);color:var(--text-primary);box-shadow:var(--shadow-float);opacity:.8;align-items:center;gap:.8rem;padding:.8rem 1.2rem;font-size:.9rem;font-weight:500;animation:6s ease-in-out infinite float;display:flex;position:absolute}.float-card i{font-size:1.4rem}.card-1{animation-delay:0s;top:15%;left:4%}.card-1 i{color:#ea4335}.card-2{animation-delay:1.5s;top:40%;right:4%}.card-2 i{color:#34a853}.card-3{animation-delay:3s;bottom:15%;left:6%}.card-3 i{color:#4285f4}.card-4{animation-delay:4.5s;bottom:15%;right:8%}.card-4 i{color:#fbbc04}.card-5{animation-delay:2s;top:12%;right:6%}.card-5 i{color:#a855f7}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-15px)rotate(2deg)}}.particle-bg{z-index:-2;pointer-events:none;opacity:.4;width:100%;height:100%;position:fixed;top:0;left:0}.hero-section{text-align:center;--mouse-x:50%;--mouse-y:50%;flex-direction:column;justify-content:center;align-items:center;min-height:80vh;padding:4rem 2rem;display:flex;position:relative;overflow:hidden}.hero-glow{background:radial-gradient(circle at var(--mouse-x) var(--mouse-y), #6366f126 0%, #6366f100 60%);z-index:-1;filter:blur(40px);width:800px;height:800px;transition:background .2s ease-out;position:absolute;top:0;left:0}.features-section{box-sizing:border-box;max-width:1200px;margin:0 auto;padding:6rem 4rem}.section-title{text-align:center;margin-bottom:5rem;font-size:2.5rem}.section-title span{color:var(--accent)}.landing-bento{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:1.5rem;display:grid}.feature-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-xl);flex-direction:column;height:100%;padding:2.5rem;transition:all .3s;display:flex;position:relative;overflow:hidden}.feature-card:hover{box-shadow:var(--shadow-bento);border-color:#ffffff26;transform:translateY(-4px)}.mini-status-badge{border-radius:var(--radius-full);color:var(--text-secondary);border:1px solid var(--bento-border);z-index:2;background:#7373731a;align-items:center;gap:.4rem;padding:.3rem .8rem;font-size:.75rem;font-weight:600;display:flex;position:absolute;top:1.5rem;right:1.5rem}.mini-status-badge.success{color:var(--success);background:#10b9811a;border-color:#10b98133}.mini-status-badge.warning{color:var(--warning);background:#f59e0b1a;border-color:#f59e0b33}.mini-status-badge.info{color:var(--info);background:#3b82f61a;border-color:#3b82f633}.mini-status-badge.pulse i{color:#ef4444;animation:2s infinite pulse}.feature-icon{border-radius:var(--radius-lg);width:60px;height:60px;color:var(--accent);background:#6366f11a;justify-content:center;align-items:center;margin-bottom:1.5rem;font-size:2rem;display:flex}.feature-card h3{margin-bottom:1rem;font-size:1.4rem}.feature-card p{color:var(--text-secondary);flex-grow:1;margin:0;font-size:.95rem;line-height:1.5}.landing-footer{text-align:center;border-top:1px solid var(--bento-border);color:var(--text-muted);margin-top:4rem;padding:3rem;font-size:.9rem}.reveal{opacity:0;transition:all .8s ease-out;transform:translateY(30px)}.reveal.active{opacity:1;transform:translateY(0)}.reveal-stagger{opacity:0;transition:opacity .8s ease-out,transform .8s cubic-bezier(.175,.885,.32,1.275);transform:translateY(40px)scale(.95)}.reveal-stagger.active{opacity:1;transform:translateY(0)scale(1)}@media (width<=768px){.landing-nav{padding:1rem 1.5rem}.hero-section{padding:4rem 1.5rem}.hero-title{font-size:2.8rem}.hero-subtitle{font-size:1.1rem}.features-section{padding:4rem 1.5rem}.landing-bento{grid-template-columns:1fr}.feature-card[style*="grid-column: span 2;"]{grid-column:span 1!important}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn-primary,.hero-cta .btn-outline{justify-content:center;width:100%}}.auth-modal{-webkit-backdrop-filter:blur(10px);z-index:2000;opacity:0;pointer-events:none;transition:var(--transition);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal.active{opacity:1;pointer-events:auto}.auth-card{background:var(--window-bg);border:1px solid var(--bento-border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-float);transition:var(--transition);padding:2.5rem;position:relative;transform:translateY(20px)}.auth-modal.active .auth-card{transform:translateY(0)}.auth-close{cursor:pointer;color:var(--text-muted);transition:var(--transition);font-size:1.2rem;position:absolute;top:1.5rem;right:1.5rem}.auth-close:hover{color:var(--text-primary)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{margin-bottom:.5rem;font-size:1.8rem}.auth-header p{color:var(--text-secondary);font-size:.95rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:500}.form-group input{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-sm);color:var(--text-primary);transition:var(--transition);padding:.75rem 1rem;font-size:.95rem}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #6366f133}.auth-error{color:var(--danger);text-align:center;border-radius:var(--radius-sm);background:#ef44441a;padding:.5rem;font-size:.85rem;display:none}.auth-error.active{display:block}.auth-btn{background:var(--accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;margin-top:.5rem;padding:.8rem;font-size:1rem;font-weight:600;display:flex}.auth-btn:hover{background:var(--accent-hover)}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.9rem}.auth-toggle{color:var(--accent);cursor:pointer;font-weight:600}.auth-toggle:hover{text-decoration:underline}.skeleton-wrapper{flex-direction:column;animation:.4s fadeIn;display:flex}.skeleton-header{border-bottom:1px solid var(--bento-border);align-items:center;gap:.75rem;padding:1.5rem 1.5rem 1rem;display:flex}.skeleton-header-icon{background:#73737326;border-radius:50%;width:24px;height:24px}.skeleton-header-text{border-radius:var(--radius-sm);background:#73737326;width:100px;height:20px}.skeleton-syncing-text{color:var(--text-muted);margin-left:auto;font-size:.85rem;animation:1.5s infinite pulseText}.skeleton-list{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.skeleton-row{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-lg);flex-direction:column;gap:.75rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.skeleton-row-top{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.skeleton-avatar-group{align-items:center;gap:.5rem;display:flex}.skeleton-avatar{background:#73737326;border-radius:50%;width:20px;height:20px}.skeleton-name{border-radius:var(--radius-sm);background:#73737326;width:140px;height:16px}.skeleton-time{border-radius:var(--radius-sm);background:#73737326;width:60px;height:12px}.skeleton-subject{border-radius:var(--radius-sm);background:#73737326;width:65%;height:18px;margin-bottom:.5rem}.skeleton-snippet{border-radius:var(--radius-sm);background:#73737326;width:100%;height:14px}.skeleton-snippet-short{border-radius:var(--radius-sm);background:#73737326;width:80%;height:14px}.shimmer{border-radius:var(--radius-sm);position:relative;overflow:hidden;background:#7373731f!important}.shimmer:before{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff14 50%,#0000 100%);width:150%;height:100%;animation:1.6s ease-in-out infinite shimmerSlide;position:absolute;top:0;left:-150%}[data-theme=light] .shimmer:before{background:linear-gradient(90deg,#0000 0%,#ffffff8c 50%,#0000 100%)}@keyframes shimmerSlide{0%{left:-150%}to{left:150%}}.skeleton-block{border-radius:var(--radius-sm);background:#7373731f;animation:1.4s ease-in-out infinite skeletonPulse;display:block}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}@keyframes pulseText{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.email-modal{-webkit-backdrop-filter:blur(10px);z-index:3000;opacity:0;pointer-events:none;transition:var(--transition);background:#0009;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.email-modal.active{opacity:1;pointer-events:auto}.email-card{background:var(--window-bg);border:1px solid var(--bento-border);border-radius:var(--radius-lg);width:100%;max-width:900px;height:90vh;box-shadow:var(--shadow-float);transition:var(--transition);flex-direction:column;display:flex;position:relative;overflow:hidden;transform:translateY(20px)}.email-modal.active .email-card{transform:translateY(0)}.email-header{border-bottom:1px solid var(--bento-border);background:var(--bento-bg);flex-direction:column;gap:1rem;padding:1.5rem 2rem;display:flex}.email-header-top{justify-content:space-between;align-items:flex-start;display:flex}.email-subject{color:var(--text-primary);margin-right:2rem;font-size:1.5rem;font-weight:700;line-height:1.3}.email-close{cursor:pointer;color:var(--text-muted);transition:var(--transition);border-radius:var(--radius-sm);padding:.2rem;font-size:1.5rem}.email-close:hover{color:var(--text-primary);background:#7373731a}.email-meta{justify-content:space-between;align-items:center;display:flex}.email-sender-info{align-items:center;gap:.75rem;display:flex}.email-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:600;display:flex}.email-sender-details{flex-direction:column;display:flex}.email-sender-name{color:var(--text-primary);font-size:.95rem;font-weight:600}.email-sender-address{color:var(--text-secondary);font-size:.8rem}.email-date{color:var(--text-muted);font-size:.85rem}.email-body-container{background:#fff;flex:1;position:relative;overflow:hidden}.email-iframe{border:none;width:100%;height:100%;display:block}.email-loading-overlay{background:var(--window-bg);z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.email-loading-spinner{color:var(--accent);font-size:2.5rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.email-modal{padding:0}.email-card{border-radius:0;max-width:100%;height:100vh}.email-header{padding:1rem}.email-subject{font-size:1.25rem}.email-meta{flex-direction:column;align-items:flex-start;gap:.5rem}}.tt-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.tt-hero-text h1{background:linear-gradient(135deg, var(--accent), #a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-size:2rem}.tt-hero-text p{color:var(--text-muted);font-size:.9rem}.tt-live-clock{letter-spacing:.04em;color:var(--accent);font-family:Outfit,monospace;font-size:1.6rem;font-weight:700}.tt-status-banner{border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:.9rem 1.25rem;font-size:.9rem;font-weight:500;animation:.4s fadeIn;display:none}.tt-status-banner.show{display:flex}.tt-status-banner.ongoing{color:var(--success);background:#10b9811f;border:1px solid #10b9814d}.tt-status-banner.upcoming{color:var(--accent);background:#6366f11f;border:1px solid #6366f14d}.tt-status-banner.done{border:1px solid var(--bento-border);color:var(--text-secondary);background:#a1a1aa1a}.tt-status-banner.warning{color:var(--warning);background:#f59e0b1f;border:1px solid #f59e0b4d}.tt-countdown-wrap{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);color:var(--text-secondary);box-shadow:var(--shadow-bento);align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:.85rem 1.25rem;font-size:.9rem;display:flex}.tt-countdown-wrap i{color:var(--accent);font-size:1.2rem}.tt-countdown-timer{color:var(--accent);letter-spacing:.06em;margin-left:auto;font-family:Outfit,monospace;font-size:1.2rem;font-weight:700}.tt-day-tabs{scrollbar-width:none;gap:.5rem;margin-bottom:1.5rem;padding-bottom:4px;display:flex;overflow-x:auto}.tt-day-tabs::-webkit-scrollbar{display:none}.tt-tab{border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--bento-border);background:var(--bento-bg);color:var(--text-secondary);transition:var(--transition);flex-shrink:0;padding:.5rem 1.1rem;font-size:.85rem;font-weight:600;position:relative}.tt-tab:hover{color:var(--text-primary);background:#7373731a}.tt-tab.active{background:var(--accent);color:#fff;border-color:#0000}.tt-tab.today-tab{border-color:var(--accent);color:var(--accent)}.tt-tab.today-tab.active{background:var(--accent);color:#fff}.tt-tab.today-tab:after{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.tt-summary-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);color:var(--text-secondary);box-shadow:var(--shadow-bento);flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:.88rem;display:flex}.tt-summary-card .tt-sum-stat{border-radius:var(--radius-full);background:#73737312;align-items:center;gap:.4rem;padding:.3rem .75rem;font-weight:500;display:flex}.tt-summary-card .tt-sum-stat i{font-size:1rem}.tt-summary-card .tt-sum-stat.green{color:var(--success)}.tt-summary-card .tt-sum-stat.blue{color:var(--accent)}.tt-summary-card .tt-sum-stat.muted{color:var(--text-muted)}.tt-cards-grid{flex-direction:column;gap:1rem;animation:.35s cubic-bezier(.16,1,.3,1) fadeSlideIn;display:flex}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tt-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);transition:var(--transition);box-shadow:var(--shadow-bento);align-items:center;gap:1.25rem;padding:1.1rem 1.25rem;display:flex;position:relative;overflow:hidden}.tt-card:hover{box-shadow:var(--shadow-float);border-color:#6366f140;transform:translateY(-2px)}.tt-card:before{content:"";background:var(--bento-border);width:4px;transition:var(--transition);border-radius:4px 0 0 4px;position:absolute;top:0;bottom:0;left:0}.tt-card.status-ongoing:before{background:var(--success);box-shadow:0 0 12px #10b98199}.tt-card.status-next:before{background:var(--accent);box-shadow:0 0 12px #6366f180}.tt-card.status-completed:before{background:var(--text-muted)}.tt-card.status-ongoing{background:linear-gradient(135deg, var(--bento-bg), #10b9810a);border-color:#10b98140;animation:3s ease-in-out infinite ongoingPulse}@keyframes ongoingPulse{0%,to{box-shadow:var(--shadow-bento)}50%{box-shadow:0 0 0 3px #10b9811f, var(--shadow-bento)}}.tt-card.status-next{border-color:#6366f133}.tt-card.status-completed{opacity:.65}.tt-card-icon{border-radius:var(--radius-sm);width:44px;height:44px;color:var(--accent);background:#6366f11a;flex-shrink:0;justify-content:center;align-items:center;font-size:1.3rem;display:flex}.tt-card.status-ongoing .tt-card-icon{color:var(--success);background:#10b9811f}.tt-card.status-completed .tt-card-icon{color:var(--text-muted);background:#73737314}.tt-card-body{flex:1;min-width:0}.tt-card-subject{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.35rem;font-size:.95rem;font-weight:600;overflow:hidden}.tt-card.status-completed .tt-card-subject{color:var(--text-muted);text-decoration:line-through}.tt-card-meta{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:1rem;font-size:.8rem;display:flex}.tt-card-meta span{align-items:center;gap:.3rem;display:flex}.tt-card-progress{background:#73737326;border-radius:4px;height:4px;margin-top:.65rem;overflow:hidden}.tt-card-progress-fill{background:linear-gradient(90deg, var(--success), #34d399);border-radius:4px;height:100%;transition:width 1s linear}.tt-badge{border-radius:var(--radius-full);letter-spacing:.05em;text-transform:uppercase;flex-shrink:0;padding:.3rem .75rem;font-size:.72rem;font-weight:700}.tt-badge.badge-ongoing{color:var(--success);background:#10b98126;border:1px solid #10b9814d}.tt-badge.badge-next{color:var(--accent);background:#6366f126;border:1px solid #6366f14d}.tt-badge.badge-completed{color:var(--text-muted);border:1px solid var(--bento-border);background:#73737314}.tt-badge.badge-upcoming{color:var(--warning);background:#f59e0b1f;border:1px solid #f59e0b4d}.tt-badge.badge-notime{color:var(--text-muted);border:1px solid var(--bento-border);background:#73737314}.tt-empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.tt-empty-state i{opacity:.4;font-size:3.5rem}.tt-empty-state h3{color:var(--text-secondary);font-size:1.1rem}.tt-empty-state p{max-width:280px;font-size:.88rem;line-height:1.6}@media (width<=640px){.tt-header{flex-direction:column;align-items:flex-start}.tt-live-clock{font-size:1.2rem}.tt-hero-text h1{font-size:1.5rem}.tt-card{flex-wrap:wrap}.tt-badge{margin-left:auto}}.cr-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.cr-course-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-bento);flex-direction:column;padding:1.25rem;display:flex}.cr-course-card:hover{box-shadow:var(--shadow-float);transform:translateY(-4px)}.cr-card-body{flex:1}.cr-card-body h3{color:var(--text-primary);margin-bottom:.35rem;font-size:1.1rem;font-weight:600;line-height:1.3}.cr-card-body p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.85rem}.cr-card-footer{align-items:center;gap:.5rem;margin-top:auto;font-size:.85rem;font-weight:500;display:flex}.cr-detail{animation:.35s cubic-bezier(.16,1,.3,1) fadeSlideIn}.cr-back-btn{color:var(--accent);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.4rem .75rem;font-size:.88rem;font-weight:500;display:inline-flex}.cr-back-btn:hover{background:#6366f11a}.cr-detail-header{background:var(--bento-bg);border:1px solid var(--bento-border);border-top:4px solid var(--accent);border-radius:var(--radius-md);box-shadow:var(--shadow-bento);margin-bottom:1.25rem;padding:1.5rem}.cr-detail-header h2{margin-bottom:.3rem;font-size:1.4rem}.cr-detail-header p{color:var(--text-secondary);font-size:.9rem}.cr-detail-tabs{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);gap:.25rem;margin-bottom:1.25rem;padding:.3rem;display:flex}.cr-dtab{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:var(--transition);text-align:center;flex:1;padding:.55rem 1rem;font-size:.88rem;font-weight:600}.cr-dtab:hover{color:var(--text-primary)}.cr-dtab.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px #6366f14d}.cr-stream-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);box-shadow:var(--shadow-bento);transition:var(--transition);margin-bottom:1rem;padding:1.25rem}.cr-stream-card:hover{box-shadow:var(--shadow-float)}.cr-stream-header{align-items:center;gap:.75rem;margin-bottom:.85rem;display:flex}.cr-stream-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.cr-stream-author{color:var(--text-primary);font-size:.9rem;font-weight:600;display:block}.cr-stream-time{color:var(--text-muted);font-size:.78rem}.cr-stream-body{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;font-size:.95rem;line-height:1.7}.cr-assignment-card{background:var(--bento-bg);border:1px solid var(--bento-border);border-radius:var(--radius-md);box-shadow:var(--shadow-bento);transition:var(--transition);margin-bottom:1rem;padding:1.25rem}.cr-assignment-card:hover{box-shadow:var(--shadow-float)}.cr-assgn-top{align-items:center;gap:.85rem;margin-bottom:.75rem;display:flex}.cr-assgn-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.cr-assgn-info{flex:1;min-width:0}.cr-assgn-info h4{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.2rem;font-size:.95rem;font-weight:600;overflow:hidden}.cr-assgn-meta{color:var(--text-muted);font-size:.78rem}.cr-assgn-desc{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;border-top:1px solid var(--bento-border);margin-top:.5rem;padding:.75rem 0;font-size:.92rem;line-height:1.65}.cr-due{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border:1px solid var(--bento-border);background:#73737314;flex-shrink:0;padding:.25rem .65rem;font-size:.72rem;font-weight:700}.cr-due.overdue{color:var(--danger);background:#ef44441f;border-color:#ef44444d}.cr-due.urgent{color:var(--warning);background:#f59e0b1f;border-color:#f59e0b4d}.cr-due.soon{color:var(--accent);background:#6366f11f;border-color:#6366f14d}.cr-materials{flex-wrap:wrap;gap:.5rem;margin-top:.85rem;display:flex}.cr-material-chip{border-radius:var(--radius-full);color:var(--accent);transition:var(--transition);background:#6366f114;border:1px solid #6366f133;align-items:center;gap:.4rem;padding:.35rem .75rem;font-size:.8rem;font-weight:500;text-decoration:none;display:inline-flex}.cr-material-chip:hover{background:#6366f12e}.cr-assgn-link{color:var(--text-muted);transition:var(--transition);align-items:center;gap:.4rem;margin-top:.75rem;font-size:.82rem;font-weight:500;text-decoration:none;display:inline-flex}.cr-assgn-link:hover{color:var(--accent)}.cr-empty{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:3rem 2rem;display:flex}.cr-empty i{opacity:.4;font-size:3rem}.cr-empty h3{color:var(--text-secondary);font-size:1rem}.cr-empty p{max-width:260px;font-size:.85rem}@media (width<=640px){.cr-grid{grid-template-columns:1fr}.cr-assgn-top{flex-wrap:wrap}.cr-due{margin-left:auto}}.jitsi-modal{z-index:9999;-webkit-backdrop-filter:blur(16px);background:#000000d9;flex-direction:column;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.jitsi-modal-header{background:var(--window-bg);border-bottom:1px solid var(--bento-border);justify-content:space-between;align-items:center;height:50px;padding:0 1.5rem;display:flex}.jitsi-modal-header h3{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1rem;display:flex}.jitsi-modal-header h3:before{content:"";background:var(--danger);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse;display:inline-block}#jitsi-iframe-wrapper{flex:1;width:100%;height:calc(100% - 50px)}.meeting-card{background:var(--bento-bg);border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);margin-bottom:.5rem;padding:.75rem;position:relative;overflow:hidden}.meeting-card:before{content:"";background:var(--accent);width:3px;position:absolute;top:0;bottom:0;left:0}.meeting-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}.meeting-card-title{color:var(--text-primary);justify-content:space-between;align-items:center;margin-bottom:.25rem;font-size:.85rem;font-weight:600;display:flex}.live-badge{color:var(--danger);border-radius:var(--radius-full);text-transform:uppercase;background:#ef444426;padding:.1rem .4rem;font-size:.65rem;font-weight:700;animation:2s infinite pulseText}.meeting-card-host{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.75rem;display:flex}.meeting-card-host img{border-radius:50%;width:16px;height:16px}.chat-container{background:rgba(var(--window-bg-rgb), .2);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid #ffffff0d;height:calc(100vh - 160px);padding:0;display:flex;position:relative;overflow:hidden}.chat-sidebar{border-right:1px solid var(--bento-border);width:340px;transition:transform var(--transition);background:#0f0f1466;flex-direction:column;display:flex}.chat-sidebar-header{justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;display:flex}.chat-sidebar-header h2{font-size:1.25rem;font-weight:600}.chat-search{padding:0 1.5rem 1rem;position:relative}.chat-search i{color:var(--text-muted);position:absolute;top:50%;left:2.2rem;transform:translateY(-50%)}.chat-search input{width:100%;color:var(--text-primary);background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;padding:.7rem 1rem .7rem 2.8rem;font-size:.9rem;transition:all .3s}.chat-search input:focus{border-color:var(--accent);background:#ffffff0f;box-shadow:0 0 0 4px #6366f126}.chat-list{scrollbar-width:none;flex:1;overflow-y:auto}.chat-list::-webkit-scrollbar{display:none}.chat-item{cursor:pointer;border-left:4px solid #0000;align-items:center;gap:1.1rem;padding:1.1rem 1.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.chat-item:hover{background:#ffffff08}.chat-item.active{border-left-color:var(--accent);background:#6366f10f;box-shadow:inset 4px 0 15px -5px #6366f14d}.chat-avatar-wrap{position:relative}.chat-avatar-wrap .profile-img{object-fit:cover;border-radius:50%;width:48px;height:48px}.chat-status-dot{background:#3f3f46;border:2.5px solid #18181b;border-radius:50%;width:14px;height:14px;transition:all .3s cubic-bezier(.175,.885,.32,1.275);position:absolute;bottom:0;right:0}.chat-status-dot.online{background:#10b981;transform:scale(1.1);box-shadow:0 0 8px #10b98166}.chat-item-info{flex:1;min-width:0}.chat-item-header{justify-content:space-between;align-items:baseline;margin-bottom:.25rem;display:flex}.chat-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.chat-item-time{color:var(--text-muted);font-size:.75rem}.chat-item-preview{justify-content:space-between;align-items:center;display:flex}.chat-item-text{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;padding-right:.5rem;font-size:.85rem;overflow:hidden}.chat-item-text.typing{color:var(--accent);font-style:italic}.chat-unread-badge{background:var(--accent);color:#fff;text-align:center;border-radius:10px;min-width:20px;padding:2px 7px;font-size:.72rem;font-weight:700;box-shadow:0 2px 8px #6366f166}.chat-empty-state{height:100%;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex}.chat-empty-state i{opacity:.5;font-size:3rem}.chat-main{background:0 0;flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.chat-main-empty{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.chat-main-empty .advanced-empty-visual{justify-content:center;align-items:center;width:200px;height:160px;margin-bottom:2rem;display:flex;position:relative}.glow-orb{filter:blur(20px);background:radial-gradient(circle,#6366f133 0%,#6366f100 70%);border-radius:50%;width:120px;height:120px;animation:4s ease-in-out infinite alternate orbPulse;position:absolute}@keyframes orbPulse{0%{opacity:.5;transform:scale(.8)}to{opacity:1;transform:scale(1.2)}}.glass-card-icon{background:rgba(var(--window-bg-rgb), .6);-webkit-backdrop-filter:blur(12px);border:1px solid var(--bento-border);border-radius:var(--radius-lg);width:64px;height:64px;color:var(--accent);box-shadow:var(--shadow-float);z-index:2;justify-content:center;align-items:center;font-size:2rem;animation:6s ease-in-out infinite floatChat;display:flex;position:relative}.glass-card-icon.mini{width:40px;height:40px;color:var(--text-muted);z-index:1;opacity:.7;font-size:1.2rem;position:absolute}.glass-card-icon.mini.left{animation:5s ease-in-out 1s infinite floatChat;top:30px;left:20px;transform:rotate(-10deg)}.glass-card-icon.mini.right{animation:7s ease-in-out .5s infinite floatChat;bottom:20px;right:20px;transform:rotate(15deg)}@keyframes floatChat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-10px)rotate(2deg)}}.chat-empty-state.advanced{padding:3rem 1.5rem;position:relative;overflow:hidden}.chat-empty-state.advanced .empty-glow{background:var(--accent);filter:blur(40px);opacity:.1;border-radius:50%;width:80px;height:80px;position:absolute;top:20px}.chat-empty-state.advanced .icon-ring{border:1px dashed var(--bento-border);width:50px;height:50px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;font-size:1.5rem;animation:20s linear infinite spinSlow;display:flex}.chat-empty-state.advanced .icon-ring i{animation:20s linear infinite spinSlowReverse}@keyframes spinSlow{to{transform:rotate(360deg)}}@keyframes spinSlowReverse{to{transform:rotate(-360deg)}}.chat-main-empty h3{color:var(--text-primary);margin-bottom:.5rem;font-family:Outfit,sans-serif;font-size:1.5rem}.chat-main-empty p{max-width:300px;line-height:1.5}.chat-header{border-bottom:1px solid var(--bento-border);-webkit-backdrop-filter:blur(10px);background:rgba(var(--window-bg-rgb), .7);z-index:10;align-items:center;padding:1rem 1.5rem;display:flex}.chat-header-profile{flex:1;align-items:center;gap:1rem;display:flex}.chat-header-info h3{font-size:1rem;font-weight:600}.chat-header-info p{color:var(--text-secondary);font-size:.8rem}.chat-header-actions{gap:.5rem;display:flex;position:relative}.chat-options-menu{background:rgba(var(--bento-bg-rgb), .95);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--bento-border);border-radius:var(--radius-md);box-shadow:var(--shadow-float);z-index:100;flex-direction:column;gap:.2rem;min-width:180px;margin-top:.5rem;padding:.5rem;position:absolute;top:100%;right:0}.chat-options-menu.show{animation:.2s ease-out forwards fadeInDown;display:flex!important}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-options-menu .menu-item{cursor:pointer;color:var(--text-primary);border-radius:6px;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.85rem;transition:background .2s;display:flex}.chat-options-menu .menu-item:hover{background:#ffffff0d}.chat-options-menu .menu-item.danger{color:var(--danger,#ef4444)}.chat-options-menu .menu-item.danger:hover{background:#ef44441a}.chat-messages{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.chat-messages-scroll{scrollbar-width:thin;scrollbar-color:var(--bento-border) transparent;flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.date-separator{text-align:center;margin:1.5rem 0;position:relative}.date-separator span{background:rgba(var(--bento-bg-rgb), .8);border-radius:var(--radius-full);color:var(--text-muted);border:1px solid var(--bento-border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.3rem 1rem;font-size:.75rem;font-weight:600}.message-wrapper{flex-direction:column;max-width:75%;animation:.3s cubic-bezier(.16,1,.3,1) forwards messageSlideFade;display:flex}@keyframes messageSlideFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-wrapper.sent{align-self:flex-end;align-items:flex-end}.message-wrapper.received{align-self:flex-start;align-items:flex-start}.message-bubble{word-break:break-word;padding:.85rem 1.1rem;font-size:.96rem;line-height:1.5;transition:all .2s;position:relative;box-shadow:0 2px 5px #0000001a}.message-wrapper.sent .message-bubble{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#4f46e5 100%);border-radius:20px 20px 4px;box-shadow:0 4px 15px #6366f133}.message-wrapper.received .message-bubble{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#e4e4e7;background:#ffffff0d;border:1px solid #ffffff14;border-radius:20px 20px 20px 4px}.message-wrapper.sent.grouped .message-bubble{border-radius:20px 4px 4px 20px}.message-wrapper.sent.grouped-last .message-bubble{border-radius:20px 4px 20px 20px}.message-wrapper.sent.grouped-first .message-bubble{border-radius:20px 20px 4px}.message-wrapper.received.grouped .message-bubble{border-radius:4px 20px 20px 4px}.message-wrapper.received.grouped-last .message-bubble{border-radius:4px 20px 20px}.message-wrapper.received.grouped-first .message-bubble{border-radius:20px 20px 20px 4px}.message-time{color:var(--text-muted);align-items:center;gap:.3rem;margin-top:.25rem;font-size:.65rem;display:flex}.message-wrapper.sent .message-time{justify-content:flex-end}.message-receipt{color:var(--text-muted);align-items:center;gap:.2rem;font-size:.8rem;display:inline-flex}.message-receipt.read{color:#3b82f6}.floating-icons{z-index:2;justify-content:center;align-items:center;display:flex;position:relative}.glass-card-icon.main{background:#6366f126;border:1px solid #6366f14d;width:72px;height:72px;font-size:2.2rem}.orbit-container{justify-content:center;align-items:center;width:200px;height:200px;display:flex;position:absolute}.orbit-path{border:1px dashed #ffffff0d;border-radius:50%;width:100%;height:100%;position:absolute}.orbit-node{background:var(--accent);width:8px;height:8px;box-shadow:0 0 10px var(--accent);offset-path:border-box;border-radius:50%;animation:10s linear infinite orbitMove;position:absolute}@keyframes orbitMove{0%{transform:rotate(0)translate(100px)rotate(0)}to{transform:rotate(360deg)translate(100px)rotate(-360deg)}}.empty-actions{margin-top:1.5rem}.chat-input-area{-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);background:#0a0a0c99;border-top:1px solid #ffffff0d;padding:1.2rem 1.8rem}.chat-input-wrapper{transition:var(--transition);background:#ffffff08;border:1px solid #ffffff14;border-radius:20px;align-items:center;gap:.75rem;padding:.6rem 1rem;display:flex;box-shadow:0 4px 20px #0003}.chat-input-wrapper input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:.5rem .2rem;font-size:.95rem}.chat-input-wrapper input::placeholder{color:var(--text-muted)}.chat-input-wrapper .btn-icon-small{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:1.2rem;transition:color .2s;display:flex}.chat-input-wrapper .btn-icon-small:hover{color:var(--text-primary)}.chat-input-wrapper .btn-primary.btn-icon-small{background:var(--accent);color:#fff;border-radius:50%;width:36px;height:36px;box-shadow:0 2px 8px #6366f166}.chat-input-wrapper .btn-primary.btn-icon-small:hover{color:#fff;background:#4f46e5}.skeleton-line{background:linear-gradient(90deg, var(--bento-border) 25%, #73737333 50%, var(--bento-border) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.d-mobile-flex{display:none}@media (width<=768px){.chat-container{border-radius:var(--radius-md);border:none;height:calc(100vh - 130px)}.chat-sidebar{z-index:10;-webkit-backdrop-filter:blur(20px);background:#0f0f14f2;width:100%;position:absolute;inset:0}.chat-sidebar.hidden{transform:translate(-100%)}.chat-main{z-index:5;position:absolute;inset:0}.d-mobile-flex{justify-content:center;align-items:center;margin-right:.5rem;display:flex}.chat-header{padding:.8rem 1rem}.chat-messages-scroll{padding:1rem}.message-wrapper{max-width:90%}.message-bubble{padding:.75rem 1rem;font-size:.9rem}.chat-input-area{padding:.6rem .8rem}.chat-input-wrapper{border-radius:24px;padding:.4rem .6rem}.chat-input-wrapper input{font-size:.9rem}}#chat.view{min-height:calc(100vh - 118px)}.chat-container.bento-box{background:linear-gradient(135deg, #6366f124, transparent 34%), linear-gradient(315deg, #14b8a61a, transparent 38%), rgba(var(--window-bg-rgb), .52);-webkit-backdrop-filter:blur(28px)saturate(145%);border:1px solid #ffffff1c;border-radius:24px;grid-template-columns:minmax(290px,34%) minmax(0,1fr);height:min(760px,100vh - 138px);min-height:560px;padding:0;display:grid;position:relative;overflow:hidden;box-shadow:0 28px 80px #00000057,inset 0 1px #ffffff0f}.chat-container:before{content:"";pointer-events:none;background:linear-gradient(90deg,#ffffff09,#0000 42%),radial-gradient(at 100% 0,#6366f12e,#0000 42%);position:absolute;inset:0}.chat-sidebar{-webkit-backdrop-filter:blur(22px);z-index:2;background:#09090d7a;border-right:1px solid #ffffff17;width:auto;min-width:0;position:relative}.chat-sidebar-header{padding:1.25rem 1.15rem .85rem}.chat-kicker{color:var(--accent-hover);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.18rem;font-size:.68rem;font-weight:700;display:block}.chat-sidebar-header h2{letter-spacing:0;font-size:clamp(1.32rem,2vw,1.7rem)}.chat-new-btn{color:#fff;background:linear-gradient(135deg, var(--accent), #14b8a6);cursor:pointer;border-radius:14px;justify-content:center;align-items:center;width:42px;height:42px;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 12px 32px #6366f152}.chat-new-btn:hover{transform:translateY(-2px);box-shadow:0 16px 42px #14b8a640,0 10px 26px #6366f14d}.chat-search{padding:0 1.15rem .75rem}.chat-search i{color:#cbd5e1b8;left:1.95rem}.chat-search input{height:44px;color:var(--text-primary);background:#ffffff0e;border:1px solid #ffffff1a;border-radius:14px;padding-left:2.55rem}.chat-search input:focus{background:#ffffff14;border-color:#818cf8b8;box-shadow:0 0 0 4px #6366f121,0 14px 34px #0000003d}.chat-rail-meta{gap:.5rem;padding:0 1.15rem .8rem;display:flex}.chat-section-pill{min-height:30px;color:var(--text-muted);background:#ffffff09;border:1px solid #ffffff12;border-radius:999px;align-items:center;gap:.35rem;padding:0 .75rem;font-size:.76rem;font-weight:650;display:inline-flex}.chat-list{scrollbar-width:thin;scrollbar-color:#94a3b847 transparent;padding:0 .75rem .9rem}.chat-list::-webkit-scrollbar{width:5px;display:block}.chat-list::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.chat-section-label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:.55rem .45rem .45rem;font-size:.7rem;font-weight:700;display:flex}.chat-item{background:#ffffff06;border:1px solid #0000;border-radius:18px;gap:.82rem;margin-bottom:.35rem;padding:.82rem .8rem}.chat-item.active{background:linear-gradient(135deg,#6366f13b,#14b8a614);border-color:#818cf86b;box-shadow:0 14px 34px #6366f129,inset 0 1px #ffffff14}.chat-item.unread .chat-item-name{color:#fff}.chat-avatar-wrap .profile-img{border:1px solid #ffffff24;width:48px;height:48px;box-shadow:0 10px 24px #0000003d}.chat-status-dot{background:#52525b;border:3px solid #101014;width:13px;height:13px;bottom:1px;right:-1px}.chat-status-dot.online{background:#22c55e;box-shadow:0 0 0 4px #22c55e29,0 0 14px #22c55ecc}.chat-item-header{gap:.7rem}.chat-item-name{letter-spacing:0}.chat-item-time{color:#94a3b8d1;flex-shrink:0;align-items:center;gap:.3rem;display:inline-flex}.chat-item-text{color:#cbd5e1b8}.chat-item-text.typing{color:#5eead4;font-weight:650}.chat-unread-badge{background:linear-gradient(135deg,#22c55e,#14b8a6);justify-content:center;align-items:center;min-width:21px;height:21px;padding:0 .42rem;display:inline-flex;box-shadow:0 0 18px #14b8a65c}.chat-main{z-index:1;background:linear-gradient(#ffffff09,#0000 22%),#08080c29;min-width:0}.chat-header{-webkit-backdrop-filter:blur(24px)saturate(150%);background:#0c0c11ad;border-bottom:1px solid #ffffff17;min-height:78px;padding:.95rem 1.2rem;position:sticky;top:0}.chat-header-profile{min-width:0}.chat-header-avatar-wrap{flex:none;position:relative}.chat-header-avatar-wrap .profile-img{object-fit:cover;border:1px solid #ffffff26;border-radius:18px;width:54px;height:54px;box-shadow:0 12px 34px #0000004d}.chat-header-status-dot{background:#52525b;border:3px solid #111116;border-radius:50%;width:15px;height:15px;position:absolute;bottom:-3px;right:-3px}.chat-header-status-dot.online{background:#22c55e;box-shadow:0 0 0 4px #22c55e24,0 0 16px #22c55eb8}.chat-header-info{min-width:0}.chat-header-info h3{letter-spacing:0;text-overflow:ellipsis;white-space:nowrap;font-size:1.05rem;overflow:hidden}.chat-header-info p{color:#cbd5e1bd;margin-top:.2rem}.chat-header-info p.online{color:#5eead4}.chat-header-actions .btn-icon-small,.chat-input-wrapper .btn-icon-small{color:#e2e8f0c7;background:#ffffff0e;border:1px solid #ffffff13;border-radius:12px;width:38px;height:38px}.chat-header-actions .btn-icon-small:hover,.chat-input-wrapper .btn-icon-small:hover{color:#fff;background:#ffffff1b;transform:translateY(-1px)}.chat-options-menu{background:#121218f0;border-color:#ffffff1f;border-radius:14px;padding:.45rem}.chat-messages{min-height:0;position:relative}.chat-messages-scroll{scrollbar-color:#94a3b847 transparent;background-color:#0000;background-image:linear-gradient(#ffffff07 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:44px 44px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;gap:.7rem;padding:1.4rem clamp(1rem,3vw,2.4rem) 1.8rem}.chat-messages-scroll::-webkit-scrollbar{width:7px}.chat-messages-scroll::-webkit-scrollbar-thumb{background:#94a3b847;border-radius:999px}.date-separator{margin:1.35rem 0 1rem}.date-separator span{color:#cbd5e1d6;background:#0f0f14bd;border-color:#ffffff17;box-shadow:0 10px 24px #0000002e}.message-bubble{letter-spacing:0;border-radius:18px;padding:.78rem 1rem;font-size:.95rem}.message-bubble a{color:inherit;text-underline-offset:3px;text-decoration:underline}.message-wrapper.sent .message-bubble{background:linear-gradient(135deg,#6366f1 0%,#7c3aed 58%,#14b8a6 140%);box-shadow:0 13px 30px #6366f13d}.message-wrapper.received .message-bubble{background:#ffffff13;border-color:#ffffff1b;box-shadow:0 10px 26px #00000029,inset 0 1px #ffffff0b}.message-time{color:#94a3b8d1;margin-top:.32rem}.typing-bubble{background:#ffffff14;border:1px solid #ffffff1a;border-radius:18px 18px 18px 5px;align-items:center;gap:.34rem;width:64px;height:38px;padding:0 .85rem;display:inline-flex}.typing-bubble span{background:#5eead4;border-radius:999px;width:6px;height:6px;animation:1.1s ease-in-out infinite typingPulse}.typing-bubble span:nth-child(2){animation-delay:.16s}.typing-bubble span:nth-child(3){animation-delay:.32s}@keyframes typingPulse{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.chat-scroll-bottom{color:#fff;opacity:0;pointer-events:none;z-index:8;cursor:pointer;background:#6366f1db;border:1px solid #ffffff29;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;transition:all .22s;display:inline-flex;position:absolute;bottom:1.1rem;right:1.35rem;transform:translateY(8px);box-shadow:0 15px 34px #6366f152}.chat-scroll-bottom.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.chat-input-area{-webkit-backdrop-filter:blur(26px)saturate(150%);background:#0a0a0e8a;border-top:1px solid #ffffff13;padding:.95rem clamp(.9rem,2.5vw,1.7rem) 1.2rem}.chat-input-wrapper{background:#fff1;border-color:#ffffff1c;border-radius:20px;min-height:58px;padding:.55rem .65rem;box-shadow:0 18px 48px #0000003b,inset 0 1px #ffffff0a}.chat-input-wrapper:focus-within{border-color:#818cf8ad;box-shadow:0 0 0 4px #6366f121,0 20px 52px #00000047}.chat-input-wrapper input{color:#fff;min-width:0}.chat-input-wrapper .btn-primary.btn-icon-small{background:linear-gradient(135deg, var(--accent), #14b8a6);width:42px;height:42px;box-shadow:0 12px 26px #6366f152}@media (width<=1024px){.chat-container.bento-box{grid-template-columns:310px minmax(0,1fr)}}@media (width<=768px){#chat.view{min-height:calc(100vh - 96px)}.chat-container.bento-box{border-radius:18px;height:calc(100vh - 122px);min-height:0;display:block}.chat-sidebar{width:100%;height:100%}.chat-sidebar.hidden{transform:translate(-105%)}.chat-header{min-height:68px;padding:.75rem .85rem}.chat-header-avatar-wrap .profile-img{border-radius:14px;width:44px;height:44px}.chat-header-actions .btn-icon-small[title=Call],.chat-header-actions .btn-icon-small[title=Search\ Messages]{display:none}.message-wrapper{max-width:88%}.chat-messages-scroll{padding:1rem .85rem 1.4rem}.chat-input-area{padding:.65rem}.chat-input-wrapper{gap:.4rem;min-height:54px}.chat-input-wrapper .btn-icon-small[title=Voice]{display:none}}@media (prefers-reduced-motion:reduce){.chat-item,.message-wrapper,.chat-new-btn,.chat-scroll-bottom,.typing-bubble span{transition:none!important;animation:none!important}}.chat-container.bento-box{box-shadow:none;-webkit-backdrop-filter:blur(10px);background:#111318;border:1px solid #ffffff14}.chat-container.bento-box:before{display:none}.chat-sidebar{background:#0f1116;border-right:1px solid #ffffff14}.chat-kicker{color:#aab2c0}.chat-new-btn{box-shadow:none;background:#222834}.chat-new-btn:hover{box-shadow:none;background:#2a3140;transform:translateY(0)}.chat-search input,.chat-input-wrapper,.chat-header-actions .btn-icon-small,.chat-input-wrapper .btn-icon-small{background:#171c24;border:1px solid #ffffff17}.chat-search input:focus,.chat-input-wrapper:focus-within{box-shadow:none;border-color:#ffffff47}.chat-rail-meta{padding-top:.1rem}.chat-section-pill{background:#151922;border-color:#ffffff14}.chat-section-pill.active{color:#f0f4fb;background:#1f2632;border-color:#ffffff26}.chat-item{background:#131821;border:1px solid #0000}.chat-item:hover{background:#191f2a;border-color:#ffffff14;transform:none}.chat-item.active{box-shadow:none;background:#202836;border-color:#ffffff2e}.chat-status-dot,.chat-header-status-dot{box-shadow:none!important}.chat-status-dot.online,.chat-header-status-dot.online{background:#22c55e}.chat-main{background:#11151c}.chat-main-empty .advanced-empty-visual{display:none}.chat-main-empty{gap:.7rem;padding:1rem}.chat-header{-webkit-backdrop-filter:blur(8px);background:#0f131af0}.chat-messages-scroll{background:#11151c;gap:.55rem}.message-wrapper{max-width:min(72%,700px)}.message-wrapper.sent .message-bubble{color:#f6f8fc;box-shadow:none;background:#2c3442}.message-wrapper.received .message-bubble{color:#e5eaf2;box-shadow:none;background:#1a202a;border:1px solid #ffffff17}.message-copy-btn{color:#a9b4c5;cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:6px;width:24px;height:24px;margin-left:.5rem;transition:opacity .12s}.message-bubble:hover .message-copy-btn{opacity:1}.message-copy-btn:hover{color:#f1f5fc;border-color:#ffffff29}.message-time{color:#93a0b3;font-size:.68rem}.date-separator span{box-shadow:none;background:#161b24}.typing-bubble{background:#1b212b;border-color:#ffffff1f}.typing-bubble span{background:#c1cada}.chat-scroll-bottom{box-shadow:none;background:#262f3d}.chat-input-area{background:#0f131af2;border-top:1px solid #ffffff14}.chat-input-wrapper .btn-primary.btn-icon-small{box-shadow:none;background:#2f3848}.chat-input-wrapper .btn-primary.btn-icon-small:hover{background:#3a4559;transform:none}.chat-profile-popup{z-index:25;opacity:0;background:#151b24;border:1px solid #ffffff1a;border-radius:12px;width:280px;padding:.9rem;transition:opacity .16s,transform .16s;position:absolute;top:74px;left:20px;transform:translateY(-6px)scale(.98)}.chat-profile-popup.show{opacity:1;transform:translateY(0)scale(1)}.chat-profile-head{align-items:center;gap:.7rem;margin-bottom:.55rem;display:flex}.chat-profile-head img{object-fit:cover;border-radius:10px;width:42px;height:42px}.chat-profile-head h4{margin:0;font-size:.95rem}.chat-profile-head p,#chatProfileEmail,#chatProfileStatus{color:var(--text-secondary);margin:0;font-size:.8rem}#chatProfileStatus.online{color:#34d399}#copyUsernameBtn{justify-content:center;width:100%;margin-top:.7rem}.username-card{width:92%;max-width:360px}.username-hint{color:var(--text-secondary);font-size:.86rem;line-height:1.4}.username-field label{color:var(--text-secondary);font-size:.85rem}.username-input-wrap{border:1px solid var(--bento-border);background:#ffffff08;border-radius:10px;align-items:center;gap:.45rem;padding:.65rem .75rem;display:flex}.username-input-wrap span{color:var(--text-muted)}.username-input-wrap input{min-width:0;color:var(--text-primary);flex:1}.username-error{color:#f87171;min-height:18px;font-size:.78rem}.menu-item.disabled{opacity:.55;pointer-events:none}.toast-stack{z-index:2000;pointer-events:none;flex-direction:column;gap:.65rem;width:min(340px,100vw - 32px);display:flex;position:fixed;bottom:22px;right:22px}.app-toast{color:#eef2f8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);opacity:0;background:#121821d1;border:1px solid #ffffff1f;border-radius:12px;align-items:center;gap:.65rem;padding:.8rem .95rem;transition:opacity .2s,transform .2s;display:flex;transform:translateY(10px);box-shadow:0 14px 36px #00000047}.app-toast.show{opacity:1;transform:translateY(0)}.app-toast.success i{color:#34d399}.app-toast.error i{color:#fb7185}.app-toast.info i{color:#93c5fd}@media (width<=768px){.chat-container.bento-box{border:none;border-radius:0;height:100vh}.chat-main{inset:0}.chat-header{z-index:20;position:sticky;top:0}.chat-input-area{z-index:20;padding-bottom:calc(.65rem + env(safe-area-inset-bottom));position:sticky;bottom:0}.chat-profile-popup{width:auto;top:68px;left:10px;right:10px}}
