:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.session-creator{max-width:500px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.creator-form{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #0000001a}.creator-form h1{margin:0 0 8px;font-size:24px;font-weight:600;color:#1a1a1a;text-align:center}.creator-form p{margin:0 0 24px;color:#666;text-align:center;font-size:16px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.timeout-input-group{display:flex;align-items:center;gap:8px}.timeout-input{flex:1;padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s ease}.timeout-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.timeout-input:disabled{background-color:#f8f9fa;color:#6c757d}.timeout-label{font-size:14px;color:#666;font-weight:500}.help-text{display:block;margin-top:4px;font-size:12px;color:#666}.error-message{display:flex;align-items:center;gap:8px;padding:12px;background-color:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:16px}.create-button{width:100%;padding:16px;background-color:#007bff;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.create-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-1px)}.create-button:disabled{background-color:#6c757d;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.info-section{margin-top:32px;padding-top:24px;border-top:1px solid #e1e5e9}.info-section h3{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}.info-section ol{margin:0;padding-left:20px;color:#666;line-height:1.6}.info-section li{margin-bottom:8px}.session-created{text-align:center}.session-info h2{margin:0 0 24px;font-size:24px;font-weight:600;color:#28a745}.session-details{background-color:#f8f9fa;border-radius:8px;padding:16px;margin-bottom:24px}.detail-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.detail-item:last-child{margin-bottom:0}.detail-item label{font-weight:500;color:#666;font-size:14px}.session-id{font-family:Monaco,Menlo,monospace;font-size:12px;background-color:#e9ecef;padding:4px 8px;border-radius:4px;color:#495057}.share-section{margin-bottom:24px}.share-section label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.share-url-container{display:flex;gap:8px}.share-url-input{flex:1;padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;font-family:Monaco,Menlo,monospace;background-color:#f8f9fa}.copy-button{padding:12px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.copy-button:hover{background-color:#545b62}.actions{display:flex;gap:12px;flex-direction:column}.join-button,.new-session-button{padding:16px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.primary:hover{background-color:#0056b3;transform:translateY(-1px)}.secondary{background-color:#f8f9fa;color:#6c757d;border:2px solid #e1e5e9}.secondary:hover{background-color:#e9ecef;border-color:#d1ecf1}@media (min-width: 768px){.session-creator{padding:40px 20px}.creator-form{padding:32px}.actions{flex-direction:row}.share-url-input{font-size:16px}}@media (prefers-color-scheme: dark){.creator-form{background:#1a1a1a;color:#fff}.creator-form h1{color:#fff}.creator-form p{color:#ccc}.form-group label{color:#ddd}.timeout-input{background-color:#2d2d2d;border-color:#444;color:#fff}.timeout-input:focus{border-color:#007bff}.session-details{background-color:#2d2d2d}.share-url-input{background-color:#2d2d2d;color:#fff;border-color:#444}}.modal-backdrop{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn .2s ease}.modal-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000004d;z-index:1001;min-width:320px;max-width:90%;animation:slideIn .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e1e5e9}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close:hover{background:#f0f0f0;color:#333}.modal-content{padding:24px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:#666;font-size:14px}.info-value{font-size:14px;color:#333;font-family:monospace;background:#f8f9fa;padding:4px 8px;border-radius:4px}.info-value.connected{color:#28a745}.info-value.disconnected{color:#dc3545}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (prefers-color-scheme: dark){.modal-container{background:#1a1a1a}.modal-header{border-color:#444}.modal-header h3{color:#fff}.modal-close{color:#ccc}.modal-close:hover{background:#2d2d2d;color:#fff}.info-row{border-color:#2d2d2d}.info-label{color:#aaa}.info-value{color:#ddd;background:#2d2d2d}}@media (max-width: 480px){.modal-container{min-width:280px}.modal-header{padding:16px 20px}.modal-content{padding:20px}.info-row{flex-direction:column;align-items:flex-start;gap:4px}.info-value{align-self:stretch;text-align:right}}.photo-capture{max-width:600px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.camera-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.camera-view{position:relative;background:#000}.camera-video{width:100%;height:auto;display:block;max-height:70vh;object-fit:cover}.camera-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:20px;display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap}.capture-button{background:#007bff;color:#fff;border:none;border-radius:50px;padding:16px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #007bff4d}.capture-button:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 6px 16px #007bff66}.capture-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.upload-option label{display:inline-block;padding:12px 24px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.upload-option label:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-1px)}.switch-camera-button{background:#fff3;border:2px solid rgba(255,255,255,.3);color:#fff;border-radius:50%;width:48px;height:48px;font-size:18px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.switch-camera-button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80}.stop-camera-button{background:#dc3545cc;color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:14px;cursor:pointer;transition:all .2s ease}.stop-camera-button:hover:not(:disabled){background:#dc3545}.camera-start{padding:20px;text-align:center}.camera-placeholder{margin-bottom:20px}.camera-icon{font-size:56px;margin-bottom:12px;opacity:.7}.camera-placeholder h3{margin:0 0 8px;font-size:19px;font-weight:600;color:#333}.camera-placeholder p{margin:0;color:#666;font-size:15px;line-height:1.5}.start-options{display:flex;flex-direction:column;gap:12px;align-items:center}.start-camera-button{background:#007bff;color:#fff;border:none;border-radius:10px;padding:14px 28px;font-size:17px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #007bff4d}.start-camera-button:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 6px 16px #007bff66}.start-camera-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.upload-option{position:relative}.upload-button{background:#f8f9fa;color:#6c757d;border:2px solid #e1e5e9;border-radius:12px;padding:16px 32px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-block;text-decoration:none}.upload-button:hover{background:#e9ecef;border-color:#d1ecf1;transform:translateY(-1px)}.captured{text-align:center}.captured-photo{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.photo-preview{width:100%;height:auto;display:block;max-height:70vh;object-fit:contain}.capture-actions{padding:20px;background:#f8f9fa}.retake-button{background:#6c757d;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.retake-button:hover{background:#545b62;transform:translateY(-1px)}.error-message{display:flex;align-items:center;gap:8px;padding:16px;background-color:#fff5f5;border:1px solid #fed7d7;color:#c53030;font-size:14px;margin:16px;border-radius:8px}@media (min-width: 768px){.photo-capture{padding:40px 20px}.camera-start{padding:60px 40px}.start-options{flex-direction:row;justify-content:center}.camera-controls{padding:24px}.capture-button{padding:18px 28px;font-size:18px}}@media (orientation: landscape) and (max-height: 600px){.camera-video{max-height:50vh}.camera-controls{position:static;background:#000c;padding:16px}.camera-start{padding:20px}.camera-icon{font-size:48px}}@media (prefers-color-scheme: dark){.camera-container{background:#1a1a1a}.camera-start{background:#1a1a1a;color:#fff}.camera-placeholder h3{color:#fff}.camera-placeholder p{color:#ccc}.upload-button{background:#2d2d2d;color:#ddd;border-color:#444}.upload-button:hover{background:#3d3d3d;border-color:#555}.captured-photo{background:#1a1a1a}.capture-actions{background:#2d2d2d}}@media (prefers-reduced-motion: reduce){.capture-button,.start-camera-button,.upload-button,.retake-button,.switch-camera-button,.stop-camera-button{transition:none;transform:none!important}.spinner{animation:none}}.capture-button:focus,.start-camera-button:focus,.upload-button:focus,.retake-button:focus,.switch-camera-button:focus,.stop-camera-button:focus{outline:3px solid rgba(0,123,255,.5);outline-offset:2px}.photo-reveal{width:100%;height:100%;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.photo-reveal.loading{text-align:center}.reveal-placeholder{background:#fff;border-radius:12px;padding:60px 20px;box-shadow:0 4px 20px #0000001a}.loading-icon{font-size:64px;margin-bottom:16px;opacity:.7}.reveal-placeholder h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#333}.reveal-placeholder p{margin:0;color:#666;font-size:16px;line-height:1.5}.photos-container{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:32px}@media (min-width: 768px){.photos-container{grid-template-columns:1fr 1fr}}.photo-section{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0000001a}.photo-label{background:#f8f9fa;padding:12px 16px;font-weight:600;color:#333;font-size:14px;text-align:center;border-bottom:1px solid #e1e5e9}.photo-frame{padding:16px;display:flex;justify-content:center;align-items:center;min-height:200px;background:#f8f9fa}.reveal-canvas{max-width:100%;max-height:300px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.error-message{display:flex;align-items:center;gap:8px;padding:16px;background-color:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:24px}.error-icon{font-size:16px}.reveal-controls{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #0000001a;margin-bottom:24px;text-align:center}.completion-message{padding:20px}.completion-message h3{margin:0 0 8px;font-size:20px;color:#28a745}.completion-message p{margin:0;color:#666;font-size:16px}.reveal-actions{display:flex;flex-direction:column;align-items:center;gap:16px}.reveal-button{background:#007bff;color:#fff;border:none;border-radius:12px;padding:16px 32px;font-size:18px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #007bff4d}.reveal-button:hover:not(:disabled){background:#0056b3;transform:translateY(-2px);box-shadow:0 6px 16px #007bff66}.reveal-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}.waiting-state,.ready-state{display:flex;flex-direction:column;align-items:center;gap:16px}.waiting-indicator{display:flex;flex-direction:column;align-items:center;gap:12px}.waiting-indicator p,.ready-state p{margin:0;color:#666;font-size:16px}.ready-state p{color:#28a745;font-weight:500}.cancel-button{background:#6c757d;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;cursor:pointer;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:#545b62}.reveal-instructions{background:#e7f3ff;border:1px solid #b3d9ff;border-radius:8px;padding:16px;margin-top:16px}.reveal-instructions p{margin:0;color:#06c;font-size:14px;line-height:1.5}.not-ready-message{padding:20px;color:#666;font-size:16px}.not-ready-message p{margin:0}.reveal-info{background:#f8f9fa;border-radius:12px;padding:20px;border:1px solid #e1e5e9}.reveal-info h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.reveal-info ul{margin:0;padding-left:20px;color:#666;line-height:1.6}.reveal-info li{margin-bottom:4px}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.primary{background-color:#007bff;color:#fff}.secondary{background-color:#6c757d;color:#fff}@media (min-width: 768px){.photo-reveal{padding:40px 20px}.reveal-controls{padding:32px}.reveal-actions{flex-direction:row;justify-content:center}.reveal-button{font-size:20px;padding:18px 36px}}@media (prefers-color-scheme: dark){.photo-reveal{color:#fff}.progress-text{color:#ccc}.photo-section{background:#1a1a1a}.photo-label{background:#2d2d2d;color:#ddd;border-color:#444}.photo-frame{background:#2d2d2d}.reveal-controls{background:#1a1a1a}.reveal-placeholder{background:#1a1a1a;color:#fff}.reveal-placeholder h3{color:#fff}.reveal-placeholder p{color:#ccc}.reveal-info{background:#2d2d2d;border-color:#444}.reveal-info h4{color:#fff}.reveal-info ul{color:#ccc}.reveal-instructions{background:#1a2332;border-color:#2d4a66}.reveal-instructions p{color:#66b3ff}}@media (prefers-reduced-motion: reduce){.reveal-button,.cancel-button{transition:none;transform:none!important}.progress-fill{transition:none}.spinner{animation:none}}.reveal-button:focus,.cancel-button:focus{outline:3px solid rgba(0,123,255,.5);outline-offset:2px}.photos-container.video-chat-layout{position:relative;display:block;width:100%;height:100%;flex:1;overflow:hidden}.remote-photo-section{position:absolute;top:0;left:0;width:100%;height:100%;background:#000}.remote-canvas{width:100%;height:100%;object-fit:cover;display:block}.remote-photo-label{position:absolute;top:16px;left:16px;background:#000000b3;color:#fff;padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-photo-overlay{position:absolute;top:16px;right:16px;width:150px;height:200px;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px #0000004d;border:2px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-photo-frame{width:100%;height:100%;position:relative}.user-canvas{width:100%;height:100%;object-fit:cover;display:block}.user-photo-label{position:absolute;bottom:0;left:0;right:0;background:#000c;color:#fff;padding:6px 8px;font-size:12px;font-weight:500;text-align:center}@media (max-width: 768px){.photos-container.video-chat-layout{height:60vh;min-height:300px}.user-photo-overlay{width:120px;height:160px;top:12px;right:12px}.remote-photo-label{top:12px;left:12px;padding:6px 10px;font-size:13px}.user-photo-label{padding:4px 6px;font-size:11px}}@media (max-width: 480px){.user-photo-overlay{width:100px;height:130px}}.reveal-progress-overlay{position:absolute;bottom:16px;left:16px;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:12px;padding:12px 16px;min-width:220px;box-shadow:0 4px 20px #0006;border:1px solid rgba(255,255,255,.1);z-index:10}.progress-bar-overlay{width:100%;height:6px;background-color:#fff3;border-radius:3px;overflow:hidden;margin-bottom:8px}.progress-fill-overlay{height:100%;background:linear-gradient(90deg,#007bff,#28a745);border-radius:3px;transition:width .3s ease;box-shadow:0 0 8px #007bff99}.progress-info{display:flex;flex-direction:column;gap:4px}.progress-text-overlay{font-size:13px;font-weight:600;color:#fff;letter-spacing:.3px}.stage-description-overlay{font-size:11px;color:#fffc;font-weight:500}@media (max-width: 768px){.reveal-progress-overlay{bottom:12px;left:12px;padding:10px 12px;min-width:180px}.progress-bar-overlay{height:5px;margin-bottom:6px}.progress-text-overlay{font-size:12px}.stage-description-overlay{font-size:10px}}@media (max-width: 480px){.reveal-progress-overlay{bottom:10px;left:10px;padding:8px 10px;min-width:150px}.progress-bar-overlay{height:4px}.progress-text-overlay{font-size:11px}.stage-description-overlay{font-size:9px}}.reveal-control-overlay{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;align-items:flex-end;gap:8px;z-index:10}.control-button-overlay{background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;border:2px solid rgba(255,255,255,.2);border-radius:16px;padding:24px 48px;font-size:30px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:16px;box-shadow:0 8px 32px #0006;min-width:240px;justify-content:center}.control-button-overlay:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 40px #0009;border-color:#ffffff4d}.control-button-overlay:disabled{opacity:.6;cursor:not-allowed;transform:none}.control-button-overlay.start-button{background:linear-gradient(135deg,#007bff,#0056b3);border-color:#007bff66;box-shadow:0 4px 20px #007bff66}.control-button-overlay.start-button:hover:not(:disabled){box-shadow:0 6px 24px #007bff99}.control-button-overlay.stop-button{background:linear-gradient(135deg,#dc3545,#c82333);border-color:#dc354566;box-shadow:0 4px 20px #dc354566}.control-button-overlay.stop-button:hover:not(:disabled){box-shadow:0 6px 24px #dc354599}.control-button-overlay.resume-button{background:linear-gradient(135deg,#28a745,#218838);border-color:#28a74566;box-shadow:0 4px 20px #28a74566}.control-button-overlay.resume-button:hover:not(:disabled){box-shadow:0 6px 24px #28a74599}.control-button-overlay.cancel-button{background:#6c757de6;border-color:#6c757d66}.waiting-text-overlay,.status-text-overlay{background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:10px 20px;border-radius:10px;font-size:16px;font-weight:500;text-align:center;border:1px solid rgba(255,255,255,.15)}.status-text-overlay{color:#ffffffe6}@media (max-width: 768px){.reveal-control-overlay{bottom:12px;right:12px}.control-button-overlay{padding:18px 36px;font-size:24px;min-width:180px}.waiting-text-overlay,.status-text-overlay{font-size:14px;padding:8px 16px}}@media (max-width: 480px){.reveal-control-overlay{bottom:10px;right:10px}.control-button-overlay{padding:14px 28px;font-size:20px;min-width:140px}.waiting-text-overlay,.status-text-overlay{font-size:12px;padding:6px 12px}}.reveal-info-section{position:absolute;bottom:100px;left:50%;transform:translate(-50%);z-index:5;max-width:90%}@media (max-width: 768px){.reveal-info-section{bottom:140px}}@media (max-width: 480px){.reveal-info-section{bottom:120px}}.reveal-info-section .reveal-instructions{background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:24px 48px;box-shadow:0 4px 20px #0006;min-width:320px}.reveal-info-section .status-message{text-align:center;color:#fff;font-size:20px;line-height:1.6}.reveal-info-section .status-message div{margin:0}.reveal-info-section .completion-message{background:#28a745f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(195,230,203,.3);border-radius:12px;padding:16px 24px;box-shadow:0 4px 20px #0006}.reveal-info-section .completion-message h3{margin:0 0 4px;font-size:18px;color:#fff}.reveal-info-section .completion-message p{margin:0;color:#fffffff2;font-size:14px}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#764ba2;background-image:linear-gradient(180deg,#667eea,#764ba2);background-size:100% 120vh;background-position:top;background-repeat:no-repeat;background-attachment:fixed}#root{width:100%;height:100%}.app{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}.app-header{background:#0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.2)}.app-header h1{margin:0;color:#fff;font-size:24px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.logo-container{display:flex;align-items:center;height:40px}.app-logo{height:100%;width:auto;transition:all .2s ease}.logo-container:hover .app-logo{filter:brightness(1.2) drop-shadow(0 2px 12px rgba(255,255,255,.6));transform:scale(1.02)}.session-info{display:flex;gap:16px;align-items:center;font-size:14px;color:#ffffffe6}.session-info span{background:#fff3;padding:4px 8px;border-radius:12px;font-weight:500}.connected{color:#4ade80!important;font-weight:600}.session-info-button{display:flex;align-items:center;gap:8px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.session-info-button:hover{background:#ffffff40;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.connection-indicator{font-size:16px;line-height:1}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;width:100%;padding:0;margin:0}.app-main-centered{align-items:center;justify-content:flex-start;padding:20px 16px;overflow-y:auto;overflow-x:hidden;gap:20px}.error-banner{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;max-width:600px;width:100%}.error-banner button{background:none;border:none;color:#dc2626;cursor:pointer;font-size:18px;padding:4px;border-radius:4px}.error-banner button:hover{background:#dc26261a}.session-waiting{background:#fffffff2;border-radius:16px;padding:24px 20px;max-width:500px;width:100%;text-align:center;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.session-waiting h2{margin:0 0 12px;color:#1f2937;font-size:22px}.session-waiting p{color:#6b7280;margin-bottom:16px;line-height:1.5;font-size:15px}.share-url{display:flex;gap:8px;margin-bottom:20px}.share-url input{flex:1;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;font-family:Monaco,Menlo,monospace;background:#f9fafb}.share-url button{padding:12px 16px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background-color .2s}.share-url button:hover{background:#2563eb}.share-url .share-button{background:#10b981}.share-url .share-button:hover{background:#059669}.status-connected{color:#059669;font-weight:600}.status-connecting{color:#d97706;font-weight:600}.capture-view{width:100%;max-width:600px;text-align:center}.capture-view h2{color:#fff;font-size:22px;margin:16px 0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.upload-progress{background:#fffffff2;border-radius:12px;padding:20px;margin-top:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:4px;transition:width .3s ease}.upload-progress p{margin:0;color:#374151;font-weight:500}.app-footer{background:#0000001a;padding:16px;text-align:center;color:#ffffffb3;font-size:14px;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 768px){.app-header{flex-direction:row;gap:12px;padding:12px 16px}.logo-container{height:32px}.session-info{flex-wrap:wrap;justify-content:center;gap:8px}}@media (max-width: 480px){.logo-container{height:28px}.app-main-centered,.session-waiting{padding:16px}.share-url{flex-direction:column}.share-url input{font-size:12px}}@media (prefers-color-scheme: dark){.session-waiting{background:#1f2937f2;color:#fff}.session-waiting h2{color:#fff}.session-waiting p{color:#d1d5db}.share-url input{background:#374151;border-color:#4b5563;color:#fff}.upload-progress{background:#1f2937f2}.upload-progress p{color:#d1d5db}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.session-waiting,.capture-view,.upload-progress{animation:fadeIn .3s ease-out}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}.loading-view{display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}@keyframes spin{to{transform:rotate(360deg)}}
