body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.qr-scanner-modal{align-items:center;animation:fadeIn .2s ease;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.qr-scanner-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;max-width:500px;padding:2rem;width:100%}.scanner-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.scanner-header h2{color:#1f2937;font-size:1.5rem;margin:0}.btn-close{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem;transition:color .2s ease}.btn-close:hover{color:#1f2937}.qr-reader{border-radius:8px;margin-bottom:1rem;overflow:hidden}.scanner-hint{color:#6b7280;font-size:.9375rem;text-align:center}.scanner-error{padding:2rem 1rem;text-align:center}.scanner-error .error-icon{font-size:3rem;margin-bottom:1rem}.scanner-error p{color:#ef4444;font-size:1rem;margin-bottom:1.5rem}@media (max-width:480px){.qr-scanner-content{padding:1.5rem}.scanner-header h2{font-size:1.25rem}}.home{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 0}.home-header{color:#fff;margin-bottom:3rem;text-align:center}.home-title{font-size:3rem;font-weight:800;margin-bottom:1rem;text-shadow:0 2px 10px #0003}.home-subtitle{font-size:1.25rem;opacity:.95}.home-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr);margin-bottom:4rem;margin-left:auto;margin-right:auto;max-width:900px}.home-card{display:flex;flex-direction:column;text-align:center;transition:box-shadow .3s ease}.home-card:hover{box-shadow:0 8px 20px #00000026}.card-icon{font-size:3rem;margin-bottom:1rem}.home-card h2{color:#1f2937;font-size:1.5rem;margin-bottom:1rem}.card-description{color:#6b7280;flex-grow:1;line-height:1.6;margin-bottom:1.5rem}.btn-large{font-size:1.1rem;margin-top:auto;padding:1rem 1.5rem;width:100%}.join-input-group{margin-bottom:1.5rem;position:relative}.join-input{font-size:1.25rem;font-weight:600;letter-spacing:.2em;padding-right:3rem;text-align:center;text-transform:uppercase}.loading-inline{border-color:#0000 #2563eb #2563eb;position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.divider{align-items:center;color:#9ca3af;display:flex;margin:1.5rem 0;text-align:center}.divider:after,.divider:before{border-bottom:1px solid #e5e7eb;content:"";flex:1 1}.divider span{font-size:.875rem;padding:0 1rem}.features{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:2rem}.features h3{color:#1f2937;font-size:1.75rem;margin-bottom:2rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.feature{text-align:center}.feature-icon{display:block;font-size:2.5rem;margin-bottom:1rem}.feature h4{color:#1f2937;font-size:1.125rem;margin-bottom:.5rem}.feature p{color:#6b7280;font-size:.875rem;line-height:1.5}@media (max-width:768px){.home-title{font-size:2rem}.home-subtitle{font-size:1rem}.home-grid{gap:1.5rem;grid-template-columns:1fr;max-width:100%}.features-grid{gap:1.5rem;grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.features-grid{grid-template-columns:1fr}}.file-upload{width:100%}.drop-zone{background-color:#f9fafb;border:2px dashed #e5e7eb;border-radius:12px;cursor:pointer;padding:3rem 2rem;text-align:center;transition:all .3s ease}.drop-content{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px}.drop-zone.dragging{background-color:#eff6ff;border-color:#2563eb;transform:scale(1.02)}.drop-zone.uploading{background-color:#f0fdf4;border-color:#10b981;cursor:default}.drop-icon{animation:bounce 2s infinite;font-size:3rem;margin-bottom:1rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.drop-text{color:#6b7280;font-size:1rem;margin-bottom:1rem}.file-input{display:none}.file-input-label{display:inline-block;margin-bottom:.75rem}.file-input-label .btn{cursor:pointer;transition:transform .2s ease,background-color .3s ease}.file-input-label .btn:hover{transform:scale(1.05)}.drop-hint{color:#9ca3af;font-size:.875rem}.upload-progress{max-width:400px;width:100%}.progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.file-name{max-width:70%}.progress-percent{color:#10b981;font-weight:700}.progress-bar{background-color:#e5e7eb;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#2563eb,#10b981);border-radius:4px;height:100%;transition:width .3s ease}@media (max-width:480px){.drop-zone{padding:2rem 1rem}.drop-icon{font-size:2.5rem}.drop-text{font-size:.875rem}}.file-list{display:flex;flex:1 1;flex-direction:column;gap:.75rem;overflow-y:auto;padding-right:.5rem}.file-list::-webkit-scrollbar{width:8px}.file-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.file-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.file-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.file-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.file-item:hover{background-color:#f3f4f6;border-color:#d1d5db;transform:translateX(4px)}.file-icon{flex-shrink:0;font-size:2rem}.file-info{flex:1 1;min-width:0}.file-name{color:#1f2937;font-weight:600;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-meta{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem}.separator{color:#d1d5db}.btn-download{flex-shrink:0;font-size:.875rem;padding:.5rem 1rem}.empty-state{color:#9ca3af;padding:3rem 1rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state p{font-size:1rem}@media (max-width:768px){.file-item{align-items:flex-start;flex-direction:column;gap:.75rem}.btn-download,.file-info{width:100%}}.text-area-container{display:flex;flex:1 1;flex-direction:column;width:100%}.text-area{border:2px solid #e5e7eb;border-radius:8px;flex:1 1;font-family:inherit;font-size:1rem;min-height:120px;padding:1rem;resize:none;transition:all .3s ease;width:100%}.text-area:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.text-area-footer{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-top:.75rem}.char-counter{color:#6b7280;font-size:.875rem;font-weight:500}.char-counter.warning{color:#f59e0b}.char-counter.danger{color:#ef4444;font-weight:600}.btn-small{font-size:.875rem;padding:.5rem 1rem}.sync-indicator{align-items:center;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;display:flex;font-size:.875rem;gap:.5rem;margin-top:.75rem;padding:.75rem}.sync-icon{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sync-text{font-weight:500}@media (max-width:480px){.text-area{font-size:.9375rem}.text-area-footer{align-items:stretch;flex-direction:column}.btn-small{width:100%}}.session-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:1.5rem 0}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.header-left{flex:1 1}.header-title{font-size:1.75rem;font-weight:700;margin-bottom:.75rem}.session-info{align-items:center;display:flex;flex-wrap:wrap;gap:2rem}.session-code-display{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:8px;display:flex;gap:.75rem;padding:.5rem 1rem}.label{font-size:.875rem;opacity:.9}.code{font-family:Courier New,monospace;font-size:1.25rem;font-weight:700;letter-spacing:.1em}.btn-icon{background:#fff3;border:none;border-radius:6px;cursor:pointer;font-size:1.125rem;padding:.375rem .625rem;transition:all .2s ease}.btn-icon:hover{background:#ffffff4d;transform:scale(1.1)}.user-count{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:8px;display:flex;font-weight:600;gap:.5rem;padding:.5rem 1rem}.online-indicator{animation:pulse 2s infinite;background-color:#10b981;border-radius:50%;height:10px;width:10px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.qr-modal{align-items:center;animation:fadeIn .2s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;max-width:400px;padding:2rem;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qr-content h3{color:#1f2937;font-size:1.5rem;margin-bottom:1.5rem}.qr-image{border-radius:8px;height:300px;margin-bottom:1rem;width:300px}.qr-content p{color:#6b7280;margin-bottom:1.5rem}.copy-notification{animation:slideInRight .3s ease,fadeOut .3s ease 1.7s;background:#10b981;border-radius:8px;box-shadow:0 4px 12px #0003;color:#fff;padding:.75rem 1.5rem;position:fixed;right:2rem;top:100px;z-index:1001}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{to{opacity:0}}@media (max-width:768px){.header-title{font-size:1.25rem}.session-info{align-items:flex-start;flex-direction:column;gap:.75rem}.header-content{align-items:stretch;flex-direction:column}.header-right,.header-right .btn{width:100%}.qr-content{margin:1rem}.qr-image{height:auto;max-width:300px;width:100%}.copy-notification{left:1rem;right:1rem}}.session{background-color:#f9fafb;min-height:100vh;padding-bottom:2rem}.session-error,.session-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.loading-spinner-large{animation:spin .8s linear infinite;border:5px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:60px;margin-bottom:1rem;width:60px}.session-loading p{color:#6b7280;font-size:1.125rem}.error-icon{font-size:4rem;margin-bottom:1rem}.session-error h2{color:#ef4444;margin-bottom:.5rem}.session-error p{color:#6b7280}.card-text{display:flex;flex-direction:column;margin-bottom:2rem;margin-top:2rem;min-height:200px}.card-text .text-area-container{flex:1 1}.session-grid{grid-gap:2rem;align-items:stretch;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.session-grid .card{display:flex;flex-direction:column;height:100%}.section-title{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;gap:.5rem;margin-bottom:1.5rem}.section-title span:first-child{font-size:1.5rem}.badge{background-color:#2563eb;border-radius:12px;color:#fff;font-size:.875rem;font-weight:600;margin-left:auto;padding:.25rem .625rem}@media (max-width:900px){.card-text{min-height:250px}.session-grid{gap:1.5rem;grid-template-columns:1fr}}@media (max-width:480px){.session-grid{grid-template-columns:1fr}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:2rem}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:scale(1.05)}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem;transition:box-shadow .3s ease}.card:hover{box-shadow:0 4px 12px #0000001a}.input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.error-message{background-color:#fef2f2;border-left:4px solid #ef4444;color:#dc2626}.error-message,.success-message{border-radius:8px;margin-top:1rem;padding:.75rem 1rem}.success-message{background-color:#f0fdf4;border-left:4px solid #10b981;color:#16a34a}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.container{padding:1rem}.card{padding:1.5rem}}
/*# sourceMappingURL=main.03d2cc69.css.map*/