:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--surface: rgba(255, 255, 255, .03);--surface-hover: rgba(255, 255, 255, .06);--glass: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--primary: #7c3aed;--primary-glow: rgba(124, 58, 237, .4);--accent: #06b6d4;--accent-glow: rgba(6, 182, 212, .4);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--font-main: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:0}.bg-orb{position:fixed;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0}.bg-orb-1{width:600px;height:600px;background:var(--primary);opacity:.15;top:-200px;right:-200px}.bg-orb-2{width:400px;height:400px;background:var(--accent);opacity:.1;bottom:-100px;left:-100px}.app{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.glass-card{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.landing-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.landing-content{text-align:center;max-width:480px;width:100%}.logo{margin-bottom:2rem}.logo h1{font-size:4rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-transform:lowercase;letter-spacing:-2px}.logo p{color:var(--text-secondary);font-size:1.1rem;margin-top:.5rem}.pin-form{padding:2.5rem;margin-top:1rem}.pin-input-wrapper{position:relative;margin-bottom:1.5rem}.pin-input{width:100%;padding:1.25rem 1.5rem;font-size:1.5rem;font-family:var(--font-mono);font-weight:600;text-align:center;letter-spacing:.5rem;background:var(--bg-secondary);border:2px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);transition:var(--transition-base);outline:none}.pin-input::placeholder{color:var(--text-muted);letter-spacing:.2rem;font-weight:400}.pin-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;font-size:1rem;font-weight:600;font-family:var(--font-main);border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-base);text-decoration:none}.btn-primary{width:100%;background:linear-gradient(135deg,var(--primary),#9333ea);color:#fff;box-shadow:0 4px 20px var(--primary-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--primary-glow)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--primary)}.error-message{color:var(--danger);font-size:.875rem;margin-top:.5rem}.create-room-prompt{margin-top:2rem;padding:1.5rem;background:#7c3aed1a;border:1px solid rgba(124,58,237,.3);border-radius:var(--radius-md);text-align:center}.create-room-prompt p{color:var(--text-secondary);margin-bottom:1rem}.role-selector{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.role-content{text-align:center;max-width:600px;width:100%}.role-content h2{font-size:2rem;margin-bottom:.5rem}.role-content p{color:var(--text-secondary);margin-bottom:2rem}.room-pin-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-xl);font-family:var(--font-mono);font-size:.875rem;color:var(--accent);margin-bottom:2rem}.role-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.role-card{padding:2.5rem 2rem;cursor:pointer;transition:var(--transition-base);text-align:center}.role-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:0 8px 40px #0000004d}.role-card.uploader:hover{border-color:var(--primary);box-shadow:0 8px 40px var(--primary-glow)}.role-card.viewer:hover{border-color:var(--accent);box-shadow:0 8px 40px var(--accent-glow)}.role-icon{font-size:3rem;margin-bottom:1rem}.role-card h3{font-size:1.25rem;margin-bottom:.5rem}.role-card p{font-size:.875rem;color:var(--text-muted);margin-bottom:0}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--glass-border);background:var(--glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1rem}.header-logo{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:1rem}.role-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface);border-radius:var(--radius-xl);font-size:.875rem}.role-badge.uploader{border:1px solid var(--primary);color:var(--primary)}.role-badge.viewer{border:1px solid var(--accent);color:var(--accent)}.btn-leave{padding:.5rem 1rem;font-size:.875rem}.dashboard-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.upload-panel{margin-bottom:2rem}.upload-zone{padding:3rem;border:2px dashed var(--glass-border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition-base);background:var(--surface)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:#7c3aed1a}.upload-zone.drag-over{transform:scale(1.01)}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-zone h3{font-size:1.25rem;margin-bottom:.5rem}.upload-zone p{color:var(--text-muted);font-size:.875rem}.upload-zone input[type=file]{display:none}.text-uploader{margin-top:1.5rem}.text-input-wrapper{position:relative}.text-input{width:100%;min-height:100px;padding:1rem;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);font-size:1rem;resize:vertical;outline:none;transition:var(--transition-base)}.text-input:focus{border-color:var(--primary)}.text-input::placeholder{color:var(--text-muted)}.text-submit-row{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem}.char-count{font-size:.75rem;color:var(--text-muted)}.btn-submit-text{padding:.5rem 1.25rem;font-size:.875rem}.pasted-image-preview{margin-bottom:1rem;padding:1rem;background:var(--glass);border:2px dashed var(--primary);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pasted-image-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:1rem}.pasted-image-remove{position:absolute;top:-.5rem;right:-.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--danger);border:2px solid var(--bg);border-radius:50%;color:#fff;font-size:1rem;cursor:pointer;transition:all .2s ease;z-index:10}.pasted-image-remove:hover:not(:disabled){transform:scale(1.1);background:#dc2626}.pasted-image-remove:disabled{opacity:.5;cursor:not-allowed}.pasted-image-content img{max-width:100%;max-height:300px;border-radius:var(--radius-md);border:1px solid var(--glass-border);box-shadow:0 4px 15px #0003}.pasted-image-actions{display:flex;gap:.75rem;width:100%;max-width:300px}.btn-sm{padding:.5rem 1rem;font-size:.875rem;flex:1}.file-list-section{margin-top:2rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-header h2{font-size:1.25rem}.file-count{font-size:.875rem;color:var(--text-muted)}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.file-card{padding:1.25rem;transition:var(--transition-base)}.file-card:hover{border-color:var(--primary);transform:translateY(-2px)}.file-preview{width:100%;height:140px;background:var(--bg-secondary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;overflow:hidden}.file-preview img{width:100%;height:100%;object-fit:cover}.file-preview-icon{font-size:3rem;color:var(--text-muted)}.file-preview-icon.loading{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.file-info h4{font-size:.9rem;font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--text-muted);margin-bottom:1rem}.file-actions{display:flex;gap:.5rem}.btn-icon{padding:.5rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.btn-icon:hover{background:var(--surface-hover);color:var(--text-primary)}.btn-icon.download:hover{border-color:var(--success);color:var(--success)}.btn-icon.delete:hover{border-color:var(--danger);color:var(--danger)}.text-card{padding:1.25rem}.text-card-content{max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono);font-size:.875rem;line-height:1.6;color:var(--text-secondary);margin-bottom:1rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-secondary)}.loading-spinner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-muted)}.spinner{width:24px;height:24px;border:2px solid var(--glass-border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:1000;display:flex;flex-direction:column;gap:.75rem}.toast{padding:1rem 1.5rem;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:0 10px 40px #0006;animation:slideIn .3s ease}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--danger)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.logo h1{font-size:3rem}.role-cards{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:1rem}.header-right{width:100%;justify-content:space-between}.dashboard-content{padding:1rem}.file-grid{grid-template-columns:1fr}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.file-preview.clickable{cursor:pointer;position:relative}.file-preview.clickable:hover img{transform:scale(1.05);transition:var(--transition-base)}.preview-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-base);border-radius:var(--radius-sm)}.preview-overlay span{font-size:2rem;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.file-preview.clickable:hover .preview-overlay{opacity:1}.preview-modal{position:fixed;inset:0;background:#000000e6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.preview-modal-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 20px 60px #00000080}.preview-close{position:absolute;top:-40px;right:0;width:36px;height:36px;background:var(--surface);border:1px solid var(--glass-border);border-radius:50%;color:var(--text-primary);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.preview-close:hover{background:var(--danger);border-color:var(--danger)}.preview-filename{margin-top:1rem;padding:.5rem 1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body:after{content:"";position:fixed;inset:-30%;width:160%;height:160%;background:radial-gradient(ellipse 70% 55% at 15% 25%,rgba(124,58,237,.14) 0%,transparent 55%),radial-gradient(ellipse 55% 65% at 85% 75%,rgba(6,182,212,.12) 0%,transparent 55%),radial-gradient(ellipse 45% 50% at 60% 10%,rgba(6,182,212,.08) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 30% 85%,rgba(124,58,237,.07) 0%,transparent 50%);animation:aurora-drift 30s ease-in-out infinite alternate;pointer-events:none;z-index:0}@keyframes aurora-drift{0%{transform:translate(0) rotate(0) scale(1)}25%{transform:translate(3%,-2%) rotate(2deg) scale(1.02)}50%{transform:translate(-2%,4%) rotate(-1deg) scale(1.04)}75%{transform:translate(4%,2%) rotate(3deg) scale(1.01)}to{transform:translate(-3%,-3%) rotate(-2deg) scale(1.03)}}@keyframes orb-float-1{0%,to{transform:translate(0) scale(1);opacity:.15}33%{transform:translate(-80px,100px) scale(1.15);opacity:.22}66%{transform:translate(60px,-60px) scale(.9);opacity:.12}}@keyframes orb-float-2{0%,to{transform:translate(0) scale(1);opacity:.1}33%{transform:translate(90px,-80px) scale(1.12);opacity:.16}66%{transform:translate(-60px,60px) scale(.88);opacity:.08}}@keyframes orb-float-3{0%,to{transform:translate(0) scale(1);opacity:.08}50%{transform:translate(70px,90px) scale(1.18);opacity:.13}}@keyframes orb-float-4{0%,to{transform:translate(0) scale(1);opacity:.07}50%{transform:translate(-80px,-60px) scale(1.1);opacity:.11}}.bg-orb-1{background:radial-gradient(circle,rgba(139,92,246,1) 0%,rgba(124,58,237,.6) 40%,transparent 70%);animation:orb-float-1 18s ease-in-out infinite}.bg-orb-2{background:radial-gradient(circle,rgba(34,211,238,1) 0%,rgba(6,182,212,.6) 40%,transparent 70%);animation:orb-float-2 22s ease-in-out infinite}.bg-orb-3{width:500px;height:500px;background:radial-gradient(circle,rgba(6,182,212,.8) 0%,rgba(6,182,212,.3) 40%,transparent 70%);top:40%;left:30%;animation:orb-float-3 26s ease-in-out infinite}.bg-orb-4{width:300px;height:300px;background:radial-gradient(circle,rgba(167,139,250,.9) 0%,rgba(124,58,237,.4) 40%,transparent 70%);bottom:20%;right:10%;animation:orb-float-4 20s ease-in-out infinite}.card-3d{position:relative;transition:box-shadow .15s ease,border-color .15s ease;will-change:transform;transform-style:preserve-3d;overflow:hidden}.card-3d:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.055) 50%,transparent 70%);background-size:200% 100%;background-position:-100% 0;transition:background-position .55s ease;pointer-events:none;border-radius:inherit;z-index:1}.card-3d:hover:after{background-position:200% 0}.category-section{margin-bottom:2.5rem}.category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.65rem 1.1rem;background:linear-gradient(90deg,rgba(255,255,255,.04) 0%,transparent 100%);border-left:3px solid var(--cat-color, var(--primary));border-radius:0 var(--radius-sm) var(--radius-sm) 0;box-shadow:inset 0 0 0 1px #ffffff0a;position:relative;overflow:hidden}.category-header:before{content:"";position:absolute;left:0;top:0;bottom:0;width:60px;background:linear-gradient(90deg,color-mix(in srgb,var(--cat-color, var(--primary)) 15%,transparent) 0%,transparent 100%);pointer-events:none}.category-icon{font-size:1.1rem}.category-title{font-size:.9rem;font-weight:600;color:var(--cat-color, var(--text-primary));letter-spacing:.02em;text-transform:uppercase}.category-count{margin-left:auto;font-size:.75rem;color:var(--text-muted);background:var(--surface);padding:.15rem .5rem;border-radius:var(--radius-xl);border:1px solid var(--glass-border)}.file-preview.doc-previewable{cursor:pointer;position:relative}.doc-preview-hint{font-size:.85rem;font-weight:600;color:#fff;letter-spacing:.04em}.doc-preview-modal{align-items:stretch;padding:1.5rem}.doc-preview-content{position:relative;width:100%;max-width:900px;max-height:90vh;margin:auto;background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px #0009;animation:fadeIn .2s ease}.doc-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--glass-border);background:var(--glass);flex-shrink:0}.doc-preview-name{font-size:.9rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 50px)}.doc-close-btn{position:static;flex-shrink:0}.doc-preview-body{flex:1;overflow:auto;min-height:0}.doc-iframe{width:100%;height:75vh;border:none;display:block;background:#fff}.doc-text-preview{padding:1.5rem;font-family:var(--font-mono);font-size:.85rem;line-height:1.7;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word}.doc-word-preview{padding:2rem 2.5rem;background:#fff;color:#1a1a1a;min-height:100%;font-family:Times New Roman,serif;font-size:1rem;line-height:1.8}.doc-word-preview h1,.doc-word-preview h2,.doc-word-preview h3{margin:1rem 0 .5rem}.doc-word-preview p{margin-bottom:.75rem}.doc-word-preview table{border-collapse:collapse;width:100%;margin:1rem 0}.doc-word-preview td,.doc-word-preview th{border:1px solid #ccc;padding:.4rem .75rem}.doc-loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--text-muted)}.doc-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem;color:var(--text-muted);font-size:1rem}.doc-error span{font-size:2.5rem}.btn-icon.preview:hover{border-color:var(--accent);color:var(--accent)}.sort-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.75rem;flex-wrap:wrap}.sort-label{font-size:.8rem;color:var(--text-muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.sort-pills{display:flex;gap:.4rem;flex-wrap:wrap}.sort-pill{padding:.3rem .85rem;font-size:.78rem;font-weight:500;font-family:var(--font-main);background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-xl);color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);white-space:nowrap}.sort-pill:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--primary)}.sort-pill.active{background:#7c3aed2e;border-color:var(--primary);color:var(--primary);font-weight:600}.format-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}.format-tab{display:flex;align-items:center;gap:.45rem;padding:.5rem 1rem;font-size:.82rem;font-weight:500;font-family:var(--font-main);background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.format-tab:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#7c3aed14,#06b6d40a);opacity:0;transition:opacity var(--transition-base)}.format-tab:hover{background:var(--surface-hover);border-color:#7c3aed80;color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed26}.format-tab:hover:before{opacity:1}.format-tab.active{background:linear-gradient(135deg,#7c3aed38,#06b6d41a);border-color:var(--primary);color:var(--text-primary);box-shadow:0 0 0 1px #7c3aed40,0 4px 20px #7c3aed33;transform:translateY(-1px)}.format-tab.active:before{opacity:1}.format-tab-icon{font-size:1rem;line-height:1}.format-tab-label{font-weight:600}.format-tab-count{padding:.1rem .4rem;font-size:.7rem;font-weight:700;background:#ffffff14;border-radius:var(--radius-xl);color:var(--text-muted);line-height:1.4}.format-tab.active .format-tab-count{background:#7c3aed40;color:var(--primary)}.filter-grid{margin-top:.5rem}.bg-stars{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.bg-star{position:absolute;border-radius:50%;background:#fff;top:calc(var(--s) * 1.88%)}.bg-star:nth-child(5n+1){left:calc(1% + var(--s) * .36%)}.bg-star:nth-child(5n+2){left:calc(20% + var(--s) * .36%)}.bg-star:nth-child(5n+3){left:calc(40% + var(--s) * .36%)}.bg-star:nth-child(5n+4){left:calc(60% + var(--s) * .36%)}.bg-star:nth-child(5n){left:calc(80% + var(--s) * .36%)}.bg-star:nth-child(3n){width:1px;height:1px;opacity:.35}.bg-star:nth-child(3n+1){width:2px;height:2px;opacity:.55}.bg-star:nth-child(3n+2){width:1.5px;height:1.5px;opacity:.45}@keyframes star-twinkle{0%,to{opacity:var(--base-op, .5);transform:scale(1)}50%{opacity:.05;transform:scale(.6)}}.bg-star{animation:star-twinkle calc(2.5s + var(--s) * .18s) ease-in-out calc(var(--s) * .12s) infinite}.folder-selector{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.folder-selector-card{max-width:500px;width:100%;padding:3rem;text-align:center}.folder-title{font-size:2.5rem;margin:0 0 .5rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.folder-subtitle{color:var(--text-secondary);margin:0 0 2rem}.folder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}.folder-button{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;background:var(--surface);border:2px solid transparent;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease;font-size:1rem;color:var(--text)}.folder-button:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 20px #22d3ee26}.folder-button.selected{border-color:var(--primary);background:linear-gradient(135deg,#22d3ee1a,#a78bfa1a);box-shadow:0 8px 20px #22d3ee33}.folder-emoji{font-size:3rem}.folder-name{font-weight:600;text-transform:capitalize}.folder-auth-form{display:flex;flex-direction:column;gap:1rem;animation:fadeIn .3s ease}.error-message{color:#ef4444;font-size:.875rem;padding:.5rem;background:#ef44441a;border-radius:var(--radius)}.folder-badge{padding:.5rem 1rem;background:var(--surface);border:1px solid var(--primary);border-radius:var(--radius-xl);font-size:.875rem;font-weight:600;color:var(--primary);text-transform:capitalize}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.folder-tabs{display:flex;gap:.5rem;padding:1rem 2rem;background:var(--glass);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow-x:auto}.folder-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--surface);border:1px solid transparent;border-radius:var(--radius-xl);cursor:pointer;transition:all .3s ease;font-size:.9rem;font-weight:500;white-space:nowrap;color:var(--text-secondary)}.folder-tab:hover{border-color:var(--primary);transform:translateY(-1px);color:var(--text)}.folder-tab.active{background:linear-gradient(135deg,#22d3ee26,#a78bfa26);border-color:var(--primary);color:var(--primary);box-shadow:0 4px 15px #22d3ee33}.folder-tab-emoji{font-size:1.2rem}.folder-tab-label{font-weight:600}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:var(--bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:2.5rem;max-width:450px;width:90%;box-shadow:0 25px 70px #0009;animation:slideUp .3s ease}.modal-content form{display:flex;flex-direction:column;gap:1rem}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:1.75rem;margin:0 0 .5rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.modal-subtitle{color:var(--text-secondary);margin:0 0 1.5rem;font-size:.95rem;text-align:center}.modal-actions{display:flex;gap:1rem;margin-top:.5rem}.modal-actions .btn{flex:1;padding:.875rem 1.5rem;font-size:1rem}.input-field{width:100%;padding:1rem 1.25rem;font-size:1rem;background:var(--surface);border:2px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text);transition:var(--transition-base);outline:none;font-family:inherit}.input-field::placeholder{color:var(--text-secondary)}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px #22d3ee1a;background:var(--bg-secondary)}.modal-content .error-message{color:#ef4444;font-size:.875rem;padding:.625rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);margin:0;text-align:center}
