@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,Instrument Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.auth-container{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-form{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:400px;padding:2rem;width:100%}.auth-form h2{color:#333;margin-bottom:1.5rem;text-align:center}.form-group{margin-bottom:1rem}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233;outline:none}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.button-group button{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:1rem;padding:.75rem;transition:background-color .2s}.btn-primary{background-color:#4a90e2}.btn-primary:hover{background-color:#3a7bc8}.btn-secondary{background-color:#6c63ff}.btn-secondary:hover{background-color:#5a52e0}.message{border-radius:4px;font-size:.9rem;margin-top:1rem;padding:.75rem;text-align:center}.message.error{background-color:#fee2e2;color:#dc2626}.message.success{background-color:#dcfce7;color:#16a34a}.redirect-text{color:#666;font-size:.9rem;margin-top:1.5rem;text-align:center}.redirect-text a{color:#4a90e2;font-weight:500;text-decoration:none}.redirect-text a:hover{text-decoration:underline}.webcam-feed{background-color:#000;border-radius:4px;pointer-events:auto}.stream-wrapper,.webcam-feed{box-sizing:border-box;height:100%;max-width:100%;overflow:hidden;position:relative;width:100%}.stream-wrapper iframe{transform-origin:center}.stream-overlay,.stream-wrapper iframe{height:100%;left:0;pointer-events:auto;position:absolute;top:0;width:100%}.stream-overlay{cursor:grab;z-index:1}.stream-overlay:active{cursor:grabbing}.stream-setup{align-items:center;background-color:#333;border-radius:4px;box-sizing:border-box;color:#fff;display:flex;flex-direction:column;height:100%;justify-content:center;max-width:100%;overflow:hidden;padding:20px;text-align:center;width:100%}.stream-input{border:1px solid #ccc;border-radius:4px;font-size:16px;margin-bottom:10px;max-width:300px;padding:10px;width:100%}.stream-help{color:#aaa;font-size:14px;margin-top:10px}.loading-state{align-items:center;background-color:#333;color:#fff;display:flex;justify-content:center}.loading-indicator{text-align:center}.loading-indicator p{font-size:16px;margin:0}.screenshot-flash{height:100%;opacity:.8;width:100%;z-index:5}.screenshot-notification{background-color:#000000b3;font-size:14px;left:50%;padding:8px 12px;transform:translateX(-50%);z-index:5}.admin-page{margin:0 auto;max-width:1200px;min-height:100vh;overflow-y:auto;padding:2rem}.admin-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:2rem}.admin-container h2{color:#333;margin-bottom:2rem}.admin-container h3{color:#555;font-size:18px;margin-bottom:15px;margin-top:0}.stream-preview{margin-bottom:30px}.preview-container{background-color:#f0f0f0;border-radius:4px;height:0;overflow:hidden;padding-bottom:56.25%;position:relative;width:100%}.preview-container iframe{height:100%;left:0;position:absolute;top:0;width:100%}.stream-form{margin-bottom:25px}.form-group{margin-bottom:1.5rem}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:16px;padding:.75rem;width:100%}.form-group input:focus,.form-group select:focus{border-color:#6c63ff;box-shadow:0 0 0 2px #6c63ff33;outline:none}.input-group{display:flex;gap:10px}.input-group input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:16px;padding:10px}.input-group input:focus{border-color:#6c63ff;box-shadow:0 0 0 2px #6c63ff33;outline:none}.submit-btn{background-color:#6c63ff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:0 20px;transition:background-color .2s}.submit-btn:hover{background-color:#5a52e0}.help-text{color:#666;font-size:14px;margin-top:8px}.help-text code{background-color:#f0f0f0;border-radius:3px;font-family:monospace;padding:2px 4px}.success-message{background-color:#d4edda;color:#155724}.error-message,.success-message{border-radius:4px;margin-bottom:1rem;padding:1rem}.error-message{background-color:#f8d7da;color:#721c24}.admin-actions{margin-top:20px;text-align:center}.back-link{background-color:#f3f4f6;border-radius:4px;color:#4b5563;display:inline-block;font-weight:500;padding:10px 20px;text-decoration:none;transition:all .2s}.back-link:hover{background-color:#e5e7eb;color:#1f2937}.loading-spinner{color:#666;padding:2rem;text-align:center}.access-denied{background-color:#f9f9f9;border-radius:6px;color:#666;padding:30px;text-align:center}.access-denied p{margin-bottom:15px}.header-buttons{align-items:center;display:flex;gap:10px}.admin-link{background-color:#6c63ff;border-radius:4px;color:#fff;display:inline-block;font-size:14px;padding:5px 10px;text-decoration:none;transition:background-color .2s}.admin-link:hover{background-color:#5a52e0}.streams-list{margin-bottom:2rem}.streams-list h3{color:#444;margin-bottom:1rem}.streams-table{border-collapse:collapse;font-size:.875rem;margin-bottom:1rem;table-layout:fixed;width:100%}.streams-table td,.streams-table th{word-wrap:break-word;border-bottom:1px solid #dee2e6;padding:.75rem;text-align:left}.streams-table th{font-size:.875rem;font-weight:600;padding:1rem .75rem}.streams-table th,.streams-table tr:hover{background-color:#f8f9fa}.streams-table td:first-child{width:30%}.streams-table td:nth-child(2){width:15%}.streams-table td:nth-child(3){width:20%}.streams-table td:last-child{width:35%}.btn{border-radius:4px;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn:disabled{opacity:.7}.btn-sm{font-size:.75rem;padding:.25rem .5rem}.btn-primary{background-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-success{background-color:#28a745;color:#fff}.btn-success:hover:not(:disabled){background-color:#218838}.btn-danger{background-color:#dc3545}.btn-danger:hover:not(:disabled){background-color:#c82333}.edit-stream-form,.new-stream-form{background-color:#f8f9fa;border-radius:8px;margin-top:2rem;padding:2rem}.edit-stream-form h3,.new-stream-form h3{color:#444;margin-bottom:1.5rem}.form-group input[type=checkbox]{margin-right:.5rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.local-stream-input{display:flex;flex-direction:column;gap:10px}.local-stream-note{color:#666;font-size:14px;font-style:italic;margin:0}.access-granted{color:#28a745;font-size:14px;font-weight:500;margin:0}.stream-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px}.stream-header h3{font-size:18px;font-weight:600;margin:0}.ptz-toggle-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s ease}.ptz-toggle-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.stream-content{align-items:flex-start;display:flex;gap:20px;margin-bottom:20px}.stream-feed{align-items:stretch;display:flex;flex:1 1;min-height:400px;position:relative}.ptz-panel{flex-shrink:0;position:relative;width:360px}@media (max-width:1200px){.stream-content{flex-direction:column}.ptz-panel{width:100%}}@media (max-width:768px){.stream-header{flex-direction:column;gap:12px;text-align:center}.ptz-toggle-btn{width:100%}}.layout-buttons{display:flex;gap:8px;margin-right:10px}.layout-btn{background-color:#fff;border:2px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.layout-btn:hover{background-color:#f8f9fa;border-color:#6c63ff}.layout-btn.active{background-color:#6c63ff;border-color:#6c63ff;color:#fff}.contrast-controls{position:relative}.contrast-controls,.contrast-toggle{align-items:center;display:flex;justify-content:center}.contrast-toggle{background-color:#fff;border:none;border-radius:50%;box-shadow:0 2px 6px #0003;cursor:pointer;font-size:20px;height:40px;transition:all .2s ease;width:40px}.contrast-toggle:hover{background-color:#f0f0f0;transform:scale(1.05)}.contrast-panel{background-color:#fff;border-radius:8px;bottom:auto;box-shadow:0 4px 12px #00000026;margin-top:8px;padding:16px;position:absolute;right:auto;top:100%;width:280px;z-index:100}.contrast-panel.position-above{bottom:100%;margin-bottom:8px;margin-top:0;top:auto}.contrast-panel.position-above.position-left,.contrast-panel.position-left{left:auto;right:0}.contrast-panel h3{color:#333;font-size:16px;margin-bottom:12px;margin-top:0}.presets{margin-bottom:16px}.presets p{color:#555;font-size:14px;margin-bottom:8px}.preset-buttons{display:flex;flex-wrap:wrap;gap:8px}.filter-sliders{gap:12px}.filter-control,.filter-sliders{display:flex;flex-direction:column}.filter-control{gap:4px}.filter-control label{color:#555;font-size:14px}.filter-control input[type=range]{width:100%}@media (max-width:768px){.contrast-panel{padding:12px;width:240px}.contrast-panel h3{font-size:14px;margin-bottom:10px}.presets p{font-size:12px}.preset-buttons{gap:6px}.preset-buttons .btn{font-size:11px;padding:4px 8px}.filter-control label{font-size:12px}.filter-sliders{gap:10px}}@media (max-width:480px){.contrast-panel{padding:10px;width:200px}.contrast-panel h3{font-size:13px;margin-bottom:8px}.presets{margin-bottom:12px}.presets p{font-size:11px;margin-bottom:6px}.preset-buttons{gap:4px}.preset-buttons .btn{font-size:10px;padding:3px 6px}.filter-control label{font-size:11px}.filter-sliders{gap:8px}.filter-control{gap:3px}}@media (max-width:360px){.contrast-panel{padding:8px;width:180px}.contrast-panel h3{font-size:12px;margin-bottom:6px}.presets{margin-bottom:10px}.presets p{font-size:10px;margin-bottom:4px}.preset-buttons{gap:3px}.preset-buttons .btn{font-size:9px;padding:2px 4px}.filter-control label{font-size:10px}.filter-sliders{gap:6px}.filter-control{gap:2px}}.btn{align-items:center;border:none;border-radius:30px;cursor:pointer;display:inline-flex;font-size:.95rem;justify-content:center;min-width:80px;padding:8px 16px;transition:all .2s ease}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049;transform:translateY(-1px)}.btn-secondary{background-color:#2196f3;color:#fff}.btn-secondary:hover{background-color:#1976d2;transform:translateY(-1px)}.btn-danger{background-color:#f44336;color:#fff}.btn-danger:hover{background-color:#d32f2f;transform:translateY(-1px)}.btn-icon{background-color:#fff;border-radius:8px;box-shadow:0 2px 6px #0003;height:40px;padding:0;width:40px}.btn-icon:hover{background-color:#f0f0f0;transform:scale(1.05)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-sm{font-size:.85rem;min-width:60px;padding:6px 12px}.btn-lg{font-size:1.1rem;min-width:100px;padding:12px 24px}.btn-full{max-width:200px;width:100%}.stream-viewer{background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.viewer-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.viewer-header h2{font-size:18px;font-weight:600;margin:0}.viewer-role{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;font-size:12px;font-weight:500;padding:6px 12px}.stream-container{align-items:center;background:#f8fafc;display:flex;flex:1 1;justify-content:center;position:relative}.stream-loading{color:#64748b;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.no-stream{color:#64748b;padding:40px 20px;text-align:center}.no-stream-icon{font-size:48px;margin-bottom:16px}.no-stream h3{color:#334155;font-size:20px;margin:0 0 8px}.no-stream p{margin:0 0 20px}.no-stream p,.stream-status{color:#64748b;font-size:14px}.stream-status{align-items:center;display:flex;gap:8px;justify-content:center;margin-bottom:20px}.stream-info-tip{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:8px;margin-top:20px;padding:16px}.stream-info-tip p{color:#1e40af;font-size:14px;line-height:1.5;margin:0}.status-indicator{border-radius:50%;height:8px;width:8px}.status-indicator.active{animation:pulse 2s infinite;background:#10b981}.status-indicator.inactive{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.youtube-stream{height:100%;width:100%}.youtube-stream iframe{border-radius:8px}.local-stream{align-items:center;height:100%;justify-content:center;padding:20px;width:100%}.local-stream,.stream-info{display:flex;flex-direction:column}.stream-info{align-items:flex-end;gap:8px;position:absolute;right:20px;top:20px}.stream-type-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#10b981e6;border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px}.stream-placeholder{color:#64748b;max-width:400px;text-align:center}.placeholder-icon{font-size:64px;margin-bottom:20px}.stream-placeholder h3{color:#334155;font-size:24px;margin:0 0 12px}.stream-placeholder p{color:#64748b;font-size:16px;line-height:1.5;margin:0 0 24px}.stream-details{background:#fffc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px}.stream-details span{background:#f1f5f9;border-radius:4px;color:#475569;font-family:Monaco,Menlo,monospace;font-size:12px;padding:4px 8px}.unknown-stream{color:#ef4444;padding:40px 20px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.unknown-stream h3{color:#dc2626;font-size:20px;margin:0 0 8px}.unknown-stream p{color:#f87171;font-size:14px;margin:0}.stream-error{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef4444e6;border-radius:8px;bottom:20px;color:#fff;left:20px;padding:16px;position:absolute;right:20px;text-align:center}.stream-error .error-icon{font-size:24px;margin-bottom:8px}.stream-error h4{font-size:16px;margin:0 0 8px}.stream-error p{font-size:14px;margin:0;opacity:.9}@media (max-width:768px){.viewer-header{padding:12px 16px}.viewer-header h2{font-size:16px}.viewer-role{font-size:11px;padding:4px 8px}.no-stream,.unknown-stream{padding:20px 16px}.error-icon,.no-stream-icon{font-size:36px}.placeholder-icon{font-size:48px}.stream-info{right:16px;top:16px}.stream-error{bottom:16px;left:16px;right:16px}}@media (prefers-color-scheme:dark){.stream-viewer{background:#1f2937;color:#f9fafb}.stream-container{background:#111827}.no-stream,.unknown-stream{color:#9ca3af}.no-stream h3,.unknown-stream h3{color:#e5e7eb}.no-stream p,.stream-placeholder,.unknown-stream p{color:#9ca3af}.stream-placeholder h3{color:#e5e7eb}.stream-placeholder p{color:#9ca3af}.stream-details{background:#1f2937cc;border-color:#374151}.stream-details span{background:#374151;color:#d1d5db}}.webcam-container-wrapper{box-sizing:border-box;display:flex;flex-direction:column;gap:20px;height:100%;overflow:hidden;padding:20px;width:100%}.top-controls{align-items:center;background-color:#f8f9fa;border-radius:6px;box-shadow:0 1px 3px #0000001a;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;min-height:40px;padding:8px 12px}@media (max-width:600px){.top-controls{min-height:32px;padding:6px 8px}.controls-container{gap:4px}.controls-container .btn{font-size:.85rem;min-width:60px;padding:6px 12px}.controls-container .btn-icon{height:32px;width:32px}.stream-select{font-size:.75rem;height:28px;min-width:140px;padding:.25rem .375rem}}@media (max-width:400px){.top-controls{min-height:28px;padding:4px 6px}.controls-container{gap:2px}.controls-container .btn{font-size:.8rem;min-width:50px;padding:4px 8px}.controls-container .btn-icon{height:28px;width:28px}.stream-select{font-size:.7rem;height:24px;min-width:120px;padding:.2rem .3rem}}.webcam-container-wrapper[data-container-width=small] .top-controls{min-height:28px;padding:4px 6px}.webcam-container-wrapper[data-container-width=small] .controls-container{gap:3px}.webcam-container-wrapper[data-container-width=small] .controls-container .btn{font-size:.8rem;min-width:50px;padding:4px 8px}.webcam-container-wrapper[data-container-width=small] .controls-container .btn-icon{height:28px;width:28px}.webcam-container-wrapper[data-container-width=small] .stream-select{font-size:.7rem;height:24px;min-width:100px;padding:.2rem .3rem}.webcam-container-wrapper[data-container-width=medium] .top-controls{min-height:32px;padding:6px 8px}.webcam-container-wrapper[data-container-width=medium] .controls-container{gap:4px}.webcam-container-wrapper[data-container-width=medium] .controls-container .btn{font-size:.85rem;min-width:60px;padding:6px 12px}.webcam-container-wrapper[data-container-width=medium] .controls-container .btn-icon{height:32px;width:32px}.webcam-container-wrapper[data-container-width=medium] .stream-select{font-size:.75rem;height:28px;min-width:140px;padding:.25rem .375rem}.controls-container{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;gap:6px;justify-content:flex-end;margin-left:auto}.controls-container>*{margin:0}.stream-selector{align-items:center;display:flex;flex-shrink:0}.stream-select{background-color:#fff;border:1px solid #ced4da;border-radius:4px;font-size:.8rem;height:32px;min-width:180px;padding:.375rem .5rem}.webcam-container{align-items:stretch;background-color:initial;cursor:default;flex:1 1;flex-direction:column;justify-content:flex-start;min-height:0;pointer-events:auto;user-select:none;-webkit-user-select:none}.webcam-box,.webcam-container{border-radius:12px;box-sizing:border-box;display:flex;max-width:100%;overflow:hidden;position:relative;touch-action:none;width:100%}.webcam-box{align-items:center;background-color:#1a1a1a;box-shadow:0 4px 12px #00000026;height:100%;justify-content:center;will-change:transform}.webcam-box:hover{cursor:grab}.webcam-box:active{cursor:grabbing}.webcam-box iframe{pointer-events:auto}.screenshot-flash,.webcam-box.zoomed iframe{pointer-events:none}.screenshot-flash{animation:flash .2s ease-out;background-color:#fff;bottom:0;left:0;opacity:.7;position:absolute;right:0;top:0}.screenshot-notification{animation:slideIn .3s ease-out;background-color:#4caf50;border-radius:4px;box-shadow:0 2px 4px #0003;color:#fff;padding:10px 20px;position:absolute;right:20px;top:20px;z-index:20}@keyframes flash{0%{opacity:.7}to{opacity:0}}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.zoom-controls{bottom:24px;left:50%;position:absolute;transform:translateX(-50%);z-index:10}.zoom-controls-group{align-items:center;display:flex;gap:10px}.zoom-controls-group .btn{min-width:100px;padding:8px 16px}.webcam-container .ptz-panel-overlay{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:12px;box-shadow:0 8px 32px #0000001a;position:absolute;right:20px;top:20px;z-index:1000}.webcam-header{align-items:center;background:#000c;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.webcam-header h2{font-size:18px;font-weight:600;margin:0}.webcam-controls{display:flex;gap:8px}.control-btn{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.control-btn:hover{background:#fff3;border-color:#ffffff80;transform:translateY(-1px)}.control-btn.active{background:#3b82f6cc;border-color:#3b82f6}.webcam-content{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:hidden;position:relative}@media (max-width:1200px){.webcam-container .ptz-panel-overlay{margin:16px;position:relative;right:auto;top:auto;width:auto}.webcam-content{flex-direction:column}}@media (max-width:768px){.webcam-header{padding:12px 16px}.webcam-header h2{font-size:16px}.control-btn{font-size:13px;padding:6px 12px}.ptz-panel{margin:8px}}@media (prefers-color-scheme:dark){.ptz-panel{background:#1f2937f2;border-color:#4b556333}.webcam-header{background:#111827e6}}.streaming-note-panel{background-color:#f3e5ab;border-radius:12px;box-shadow:0 4px 12px #00000026;box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:16px;width:100%}.streaming-note-panel-empty,.streaming-note-panel-loading{align-items:center;color:#666;font-size:.95rem;justify-content:center;text-align:center}.streaming-note-panel-hint{color:#888;font-size:.85rem;margin-top:8px}.streaming-note-panel-open-btn{align-items:center;background:#0074a4;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;margin-top:16px;padding:10px 20px;transition:background .2s ease,transform .2s ease}.streaming-note-panel-open-btn:hover{background:#005a7a;transform:translateY(-1px)}.streaming-note-panel-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.streaming-note-panel-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:480px;overflow:hidden;width:90%}.streaming-note-panel-modal h3{color:#333;font-size:1.25rem;font-weight:600;margin:0;padding:20px 20px 12px}.streaming-note-panel-modal-search{border:1px solid #ddd;border-radius:8px;font-size:1rem;margin:0 20px 16px;padding:10px 14px}.streaming-note-panel-modal-search:focus{border-color:#0074a4;outline:none}.streaming-note-panel-modal-list{flex:1 1;max-height:50vh;min-height:200px;overflow-y:auto;padding:0 20px 20px}.streaming-note-panel-modal-empty,.streaming-note-panel-modal-loading{color:#666;font-size:.95rem;padding:2rem;text-align:center}.streaming-note-panel-modal-item{align-items:flex-start;background:#f8f8f8;border:1px solid #e8e8e8;border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px 14px;text-align:left;transition:background .2s ease,border-color .2s ease;width:100%}.streaming-note-panel-modal-item:hover{background:#e7f3ff;border-color:#0074a4}.streaming-note-panel-modal-item-icon{color:#0074a4;flex-shrink:0}.streaming-note-panel-modal-item-content{flex:1 1;min-width:0}.streaming-note-panel-modal-item-title{color:#333;font-size:.95rem;font-weight:600;margin-bottom:4px}.streaming-note-panel-modal-item-preview{color:#666;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.streaming-note-panel-modal-item-date{color:#888;font-size:.75rem;margin-top:4px}.streaming-note-panel-modal-close{background:#e0e0e0;border:none;border-radius:8px;cursor:pointer;font-size:1rem;margin:0 20px 20px;padding:10px 20px;transition:background .2s ease}.streaming-note-panel-modal-close:hover{background:#d0d0d0}.streaming-note-panel-status{flex-shrink:0;margin-bottom:8px;min-height:20px}.streaming-note-panel-saving{color:#0074a4;font-size:.85rem}.streaming-note-panel-body{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.streaming-note-panel-title{background-color:#ffffffe6;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:1.1rem;font-weight:600;margin-bottom:10px;padding:10px 12px;width:100%}.streaming-note-panel-title:focus{border-color:#0074a4;outline:none}.streaming-note-panel-content{background-color:#ffffffe6;border:1px solid #ddd;border-radius:8px;box-sizing:border-box;flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.5;min-height:120px;padding:10px 12px;resize:none;width:100%}.streaming-note-panel-content:focus{border-color:#0074a4;outline:none}.streaming-note-panel::-webkit-scrollbar{width:8px}.streaming-note-panel::-webkit-scrollbar-thumb{background-color:#888;border-radius:4px}.streaming-note-panel::-webkit-scrollbar-track{background-color:#f3e5ab80}.ai-assistant-container{background-color:#f5f5f5;border:1px solid #e0e0e0;border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-width:100%;min-height:0;overflow:hidden;padding:24px;position:relative;width:100%}.ai-assistant-logo{cursor:pointer;flex-shrink:0;height:60px;margin-bottom:15px;transition:transform .2s ease;width:60px}.ai-assistant-logo:hover{transform:scale(1.1)}.ai-assistant-logo img{height:100%;object-fit:contain;width:100%}.ai-assistant-buttons{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;gap:12px;min-height:0;overflow-y:auto;padding:15px;position:relative;width:100%}.ai-assistant-buttons button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;overflow:hidden;padding:12px 15px;text-align:left;text-overflow:ellipsis;transition:background .2s ease;white-space:nowrap;width:100%}.ai-assistant-buttons button:hover{background:#0056b3}.ai-assistant-buttons button:disabled{background:#ccc;cursor:not-allowed}.custom-topic-section{border-top:1px solid #eee;display:flex;flex-direction:column;gap:8px;margin-top:8px;padding-top:8px}.custom-topic-section input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.image-section{border-top:1px solid #eee;display:flex;flex-direction:column;gap:10px;margin-top:8px;padding-top:8px}.image-upload-label{background:#28a745;border-radius:4px;box-sizing:border-box;color:#fff;cursor:pointer;display:inline-block;padding:10px 15px;text-align:center;transition:background .2s ease;width:100%}.image-upload-label:hover{background:#218838}.preview-image{border:1px solid #ddd;border-radius:4px;margin:0;max-height:150px;max-width:100%;object-fit:contain}.ai-response-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1001}.ai-response-content{background:#fff;border-radius:8px;max-height:80vh;max-width:600px;overflow-y:auto;padding:20px;position:relative;width:90%}.ai-response{line-height:1.5;margin-bottom:20px}.close-response{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:5px 10px;position:absolute;right:10px;top:10px}.close-response:hover{background:#c82333}.no-concept-message{background:#f8f9fa;border-radius:4px;color:#6c757d;font-size:14px;margin-bottom:8px;padding:10px;text-align:center}.sidebar{align-self:stretch;flex-shrink:0;padding:16px 8px 16px 16px;z-index:10}.sidebar,.sidebar-toolbar{box-sizing:border-box;display:flex;flex-direction:column}.sidebar-toolbar{align-items:center;background:#fff;border:2px solid #000;border-radius:186px;box-shadow:0 4px 6px #0000001a;height:100%;justify-content:space-between;padding:clamp(24px,4vh,48px) 0;width:clamp(100px,10vw,132px)}.sidebar-top{gap:1rem}.sidebar-bottom,.sidebar-item,.sidebar-top{align-items:center;display:flex;flex-direction:column;width:100%}.sidebar-item{color:#000;justify-content:center;padding:10px;text-decoration:none;transition:color .2s ease}.sidebar-item.active,.sidebar-item.active .sidebar-icon,.sidebar-item:hover{color:#0074a4}.sidebar-item.active .sidebar-label{font-weight:700}.sidebar-icon{height:clamp(24px,3vw,32px);margin-bottom:4px;width:clamp(24px,3vw,32px)}.sidebar-label{font-size:clamp(.7rem,.9vw,.9rem);font-weight:500;line-height:1.2;text-align:center}.sidebar-divider{border-top:1.5px solid #000;height:0;margin:8px 0;width:60%}.notes-component{width:100%}.notes-component,.notes-container{display:flex;flex-direction:column;height:100%;min-height:0}.notes-container{background:#fff;border:2px solid #000;border-radius:12px;box-shadow:0 10px 24px #00000014;box-sizing:border-box;overflow:hidden;padding:20px;width:99%}.notes-header{flex-shrink:0;margin-bottom:clamp(15px,2vh,27px)}.notes-tag{height:clamp(40px,5vh,58px);margin-left:-30px;position:relative;width:clamp(200px,25vw,326px)}.notes-tag-bg{background:#e7f3ff;border:1px solid #000;border-radius:30px;box-shadow:0 2px 4px #0000001a;height:100%;left:50%;position:absolute;transform:translateX(-50%);width:80%}.notes-tag-text{color:#333;font-size:clamp(1rem,1.5vw,1.2rem);font-weight:600;left:50%;line-height:1.5;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1}.notes-grid{display:flex;flex:1 1;flex-wrap:wrap;gap:16px;overflow-y:auto;padding:4px 5px 4px 0}.notes-grid::-webkit-scrollbar{width:8px}.notes-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.notes-grid::-webkit-scrollbar-thumb{background:#0074a4;border-radius:4px}.notes-grid::-webkit-scrollbar-thumb:hover{background:#005a7a}.note-card{background:#ffffffe6;border:2px solid #352f36;border-radius:5px;box-shadow:0 3px 10px -4px #2a3d41;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;height:clamp(150px,18vh,198px);padding:clamp(10px,1.2vh,16px) clamp(12px,1.5vw,18px);transition:transform .2s ease,box-shadow .2s ease;width:clamp(120px,12vw,153px)}.note-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.note-title{color:#333;font-size:clamp(.75rem,.9vw,.9rem);font-weight:600;line-height:1.4;margin-bottom:clamp(4px,.5vh,7px)}.note-image{border-radius:4px;height:clamp(50px,6vh,75px);margin:clamp(4px,.5vh,8px) 0;overflow:hidden;width:100%}.note-image img{height:100%;object-fit:cover;width:100%}.note-content{color:#666;flex:1 1;font-size:clamp(.65rem,.75vw,.75rem);font-weight:400;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap;word-break:break-word}.note-folder{background:#ffffffe6;border:2px solid #352f36;border-radius:5px;box-shadow:0 3px 10px -4px #2a3d41;box-sizing:border-box;cursor:pointer;flex-shrink:0;height:clamp(150px,18vh,198px);overflow:hidden;padding:clamp(10px,1.2vh,16px) clamp(12px,1.5vw,18px);transition:transform .2s ease,box-shadow .2s ease;width:clamp(120px,12vw,153px)}.note-folder:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.folder-item{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;gap:6px;height:100%;justify-content:center;overflow:hidden;padding:0;width:100%}.folder-icon{color:#0074a4;flex-shrink:0;height:clamp(36px,4vw,48px);transition:color .2s ease;width:clamp(36px,4vw,48px)}.note-folder:hover .folder-icon{color:#005a7a}.folder-label{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;color:#333;display:-webkit-box;font-size:clamp(.75rem,.9vw,.9rem);font-weight:600;line-height:1.4;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;word-break:break-word}.notes-footer{flex-shrink:0;margin-top:clamp(10px,1.5vh,20px);text-align:right}.view-all-link{color:#007bff;cursor:pointer;font-size:clamp(.95rem,1.2vw,1.1rem);font-weight:600;line-height:1.5;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#0056b3;text-decoration:underline}.notes-card-link{color:inherit;text-decoration:none}.notes-empty,.notes-error,.notes-loading{color:#666;font-size:.95rem;padding:2rem;text-align:center;width:100%}.notes-error{color:#c0392b}.insights-component{flex:1 1;flex-direction:column}.insights-component,.insights-container{display:flex;height:100%;min-height:0;width:100%}.insights-container{background:#fff;border:2px solid #000;border-radius:12px;box-shadow:0 10px 24px #00000014;box-sizing:border-box;flex-direction:column;overflow:hidden;padding:20px}.insights-header{flex-shrink:0;margin-bottom:clamp(20px,3vh,42px)}.insights-tag{height:clamp(40px,5vh,58px);margin-left:-30px;position:relative;width:clamp(180px,20vw,252px)}.insights-tag-bg{background:#e7f3ff;border:1px solid #000;border-radius:30px;box-shadow:0 2px 4px #0000001a;height:100%;left:50%;position:absolute;transform:translateX(-50%);width:80%}.insights-tag-text{color:#333;font-size:clamp(1rem,1.5vw,1.2rem);font-weight:600;left:50%;line-height:1.5;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1}.insights-content{align-items:center;display:flex;flex:1 1}.insights-message{color:#333;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:400;line-height:1.5;margin:0;max-width:644px;width:100%}.ta-component{flex:1 1;flex-direction:column}.ta-component,.ta-container{display:flex;height:100%;min-height:0;width:100%}.ta-container{background:#fff;border:2px solid #000;border-radius:12px;box-shadow:0 10px 24px #00000014;box-sizing:border-box;flex-direction:column;overflow:hidden;padding:20px;position:relative}.ta-header{flex-shrink:0;margin-bottom:auto}.ta-tag{height:clamp(40px,5vh,58px);margin-left:-30px;position:relative;width:clamp(180px,20vw,252px)}.ta-tag-bg{background:#e7f3ff;border:1px solid #000;border-radius:30px;box-shadow:0 2px 4px #0000001a;height:100%;transform:translateX(-50%);width:80%}.ta-tag-bg,.ta-tag-text{left:50%;position:absolute}.ta-tag-text{color:#333;font-size:clamp(1rem,1.5vw,1.2rem);font-weight:600;line-height:1.5;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1}.ta-input-section{background:#f8f9fa;border-radius:0 0 12px 12px;border-top:1px solid #dee2e6;box-sizing:border-box;flex-shrink:0;height:auto;margin-top:auto;min-height:clamp(60px,8vh,80px);padding:clamp(10px,1.5vh,14px) clamp(15px,2vw,20px);width:100%}.ta-form{height:100%;width:100%}.ta-input-container{align-items:center;display:flex;gap:clamp(8px,1vw,13px);height:clamp(40px,5vh,52px);width:100%}.ta-input{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;flex:1 1;font-size:clamp(.9rem,1.2vw,1rem);font-weight:400;height:100%;line-height:1.5;outline:none;padding:0 clamp(12px,2vw,20px);transition:border-color .2s ease}.ta-input::placeholder{color:#999}.ta-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff33}.ta-send-button{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:0;transition:transform .2s ease,opacity .2s ease}.ta-send-button:hover{opacity:.7;transform:scale(1.1)}.ta-send-button:active{transform:scale(.95)}.ta-send-icon{color:#333;height:clamp(24px,3vw,32px);width:clamp(24px,3vw,32px)}.note-editor{background:#fff;border:2px solid #000;border-radius:12px;box-shadow:0 10px 24px #00000014;display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.note-editor-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.note-editor-back{align-items:center;background:#0000;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:.95rem;gap:8px;padding:8px 12px;transition:background .2s ease,border-color .2s ease}.note-editor-back:hover{background:#f5f5f5;border-color:#0074a4;color:#0074a4}.note-editor-status{color:#666;font-size:.85rem}.note-editor-saving{color:#0074a4}.note-editor-saved{color:#28a745}.note-editor-body{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:16px}.note-editor-title{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:1.25rem;font-weight:600;margin-bottom:12px;padding:12px 16px;width:100%}.note-editor-title:focus{border-color:#0074a4;box-shadow:0 0 0 2px #0074a433;outline:none}.note-editor-content{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;flex:1 1;font-family:inherit;font-size:1rem;line-height:1.6;min-height:200px;padding:12px 16px;resize:none;width:100%}.note-editor-content:focus{border-color:#0074a4;box-shadow:0 0 0 2px #0074a433;outline:none}.note-editor-actions{border-top:1px solid #e0e0e0;flex-shrink:0;padding:12px 16px}.note-editor-streaming-btn{align-items:center;background:#0074a4;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:8px;padding:10px 20px;transition:background .2s ease,transform .2s ease}.note-editor-streaming-btn:hover{background:#005a7a;transform:translateY(-1px)}.home-page{background:#f5f5f5;flex-direction:column;font-family:Instrument Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden;width:100vw}.home-loading,.home-page{display:flex;height:100vh}.home-loading{align-items:center;color:#666;font-size:1.2rem;justify-content:center}.home-body{flex:1 1;min-width:0}.home-header{width:100%}.home-header-content{align-items:center;display:flex;flex:1 1;gap:2rem;min-width:0}.home-greeting{color:#000;font-family:Instrument Sans,sans-serif;font-size:clamp(1.5rem,3vw,2.5rem);font-weight:500;line-height:1.22;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-logo{align-items:center;display:flex;flex-shrink:0;height:clamp(25px,2.5vh,37px);justify-content:center;width:clamp(80px,8vw,129px)}.logo-image{max-height:300%;max-width:300%;object-fit:contain}.join-class-button{background:#0074a4;border:1px solid #0074a4;border-radius:12px;color:#fff;cursor:pointer;flex-shrink:0;font-family:Instrument Sans,sans-serif;font-size:1rem;font-weight:500;min-width:160px;padding:.75rem 1.5rem;transition:background-color .2s ease,transform .2s ease}.join-class-button:hover{background:#005a7a;border-color:#005a7a;transform:translateY(-1px)}.join-class-button:active{transform:translateY(0)}.home-main{box-sizing:border-box;display:flex;flex:1 1;gap:clamp(8px,1vw,16px);min-height:0;min-width:0;overflow:hidden;padding:clamp(20px,3vh,54px) clamp(8px,1vw,16px)}.home-left-column{margin-left:-8px}.home-left-column,.home-right-column{display:flex;flex:1 1;flex-direction:column;min-height:0;min-width:0}.home-right-column{gap:clamp(8px,1vw,16px);margin-left:-10px;margin-right:8px}@media (max-width:1200px){.home-header{padding:1rem}.home-header,.home-header-content{flex-wrap:wrap}.home-greeting{white-space:normal}.home-main{flex-direction:column;padding:1rem}.home-left-column,.home-right-column{flex:1 1 auto;width:100%}}@media (max-width:768px){.home-header,.home-page{flex-direction:column}.home-header{align-items:flex-start;gap:1rem}.join-class-button{width:100%}}.notes-storage-page{background:#f5f5f5;display:flex;flex-direction:column;font-family:Instrument Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh;overflow:hidden;width:100vw}.notes-storage-loading{color:#666;font-size:1.2rem;height:100vh}.notes-storage-loading,.notes-storage-loading-inline{align-items:center;display:flex;justify-content:center}.notes-storage-loading-inline{flex:1 1;height:auto;min-width:0}.notes-storage-content{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden;padding:0}.notes-storage-header{align-items:center;box-sizing:border-box;display:flex;flex-shrink:0;justify-content:space-between;min-height:80px;padding:0 2rem;width:100%}.notes-storage-header-left{align-items:flex-start;display:flex;flex-direction:column;gap:.25rem}.notes-storage-breadcrumb{color:#000;cursor:pointer;font-family:Instrument Sans,sans-serif;font-size:clamp(1rem,2vw,1.5rem);font-weight:500;line-height:1.22;transition:color .2s ease}.notes-storage-breadcrumb:hover{color:#0074a4}.notes-storage-title-row{align-items:center;display:flex;gap:.75rem}.notes-storage-title{color:#000;font-family:Instrument Sans,sans-serif;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:500;line-height:1.22;margin:0;padding:0}.notes-storage-header-right{align-items:center;display:flex;gap:1rem;position:relative}.notes-storage-new-btn{align-items:center;background:#0074a4;border:none;border-radius:24px;color:#fff;cursor:pointer;display:flex;font-family:Instrument Sans,sans-serif;font-size:.95rem;font-weight:600;gap:.4rem;padding:.55rem 1rem;transition:background-color .2s ease;white-space:nowrap}.notes-storage-new-btn:hover{background:#005a7a}.notes-storage-new-chevron{transition:transform .2s ease}.notes-storage-new-chevron.open{transform:rotate(180deg)}.notes-storage-new-dropdown{background:#1a1a1a;border-radius:12px;box-shadow:0 8px 24px #0000004d;min-width:180px;overflow:hidden;padding:.5rem 0;position:absolute;right:0;top:calc(100% + 6px);z-index:50}.notes-storage-new-dropdown-item{align-items:center;background:#0000;border:none;color:#fff;cursor:pointer;display:flex;font-family:Instrument Sans,sans-serif;font-size:.95rem;font-weight:400;gap:.75rem;padding:.75rem 1.25rem;text-align:left;transition:background-color .15s ease;width:100%}.notes-storage-new-dropdown-item:hover{background:#ffffff1a}.notes-storage-main{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:1.5rem 2rem}.notes-storage-list{background:#fff;border:2px solid #000;border-radius:12px;box-shadow:0 10px 24px #00000014;flex:1 1;overflow-x:hidden;overflow-y:auto}.notes-storage-list::-webkit-scrollbar{width:8px}.notes-storage-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.notes-storage-list::-webkit-scrollbar-thumb{background:#0074a4;border-radius:4px}.notes-storage-item{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:1rem;padding:1rem 1.5rem;transition:background-color .2s ease}.notes-storage-item:last-child{border-bottom:none}.notes-storage-item:hover{background:#f8f9fa}.notes-storage-item-folder .notes-storage-item-icon{color:#0074a4}.notes-storage-item-note .notes-storage-item-icon{color:#555}.notes-storage-item-icon{flex-shrink:0;height:28px;width:28px}.notes-storage-item-content{flex:1 1;min-width:0}.notes-storage-item-title{color:#333;font-size:1rem;font-weight:500}.notes-storage-item-meta{color:#666;font-size:.8rem;margin-top:.25rem}.notes-storage-item-date{color:#666;flex-shrink:0;font-size:.8rem}.notes-storage-empty{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.notes-storage-empty-icon{color:#ccc;height:64px;margin-bottom:1rem;width:64px}.notes-storage-modal-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.notes-storage-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:90vw;min-width:320px;padding:1.5rem 2rem}.notes-storage-modal h3{font-size:1.25rem;margin:0 0 1rem}.notes-storage-modal input{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-size:1rem;margin-bottom:1rem;padding:.75rem;width:100%}.notes-storage-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.notes-storage-modal-actions button{border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:.5rem 1rem}.notes-storage-modal-cancel{background:#eee;color:#333}.notes-storage-modal-cancel:hover{background:#ddd}.notes-storage-modal-submit{background:#0074a4;color:#fff}.notes-storage-modal-submit:hover{background:#005a7a}@media (max-width:768px){.notes-storage-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1rem}}.App{background-color:#f5f5f5;display:flex;flex-direction:column;height:100vh;text-align:center}.page-header-shared{align-items:center;background:#fff;border-bottom:3px solid #352f36;box-sizing:border-box;display:flex;flex-shrink:0;justify-content:space-between;min-height:80px;padding:0 2rem;width:100%}.page-body-shared{display:flex;flex:1 1;flex-direction:row;min-height:0;overflow:hidden}.loading{align-items:center;color:#666;font-size:1.2rem;justify-content:center}.app-container,.loading{display:flex;height:100vh}.app-container{box-sizing:border-box;flex-direction:column;margin:0;padding:0;width:100%}.header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;padding:20px}.header h1{color:#333;font-size:1.8rem;margin:0}.main-content{align-items:stretch;background-color:initial;box-sizing:border-box;display:flex;flex:1 1;height:calc(100vh - 120px);max-width:100%;min-height:0;overflow:hidden;width:100%}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:1rem 2rem;position:sticky;top:0;z-index:1000}.app-header h1{color:#333;font-size:1.5rem;font-weight:600;margin:0}.sign-out-btn:hover{background-color:#c82333!important}.admin-page-wrapper{display:flex;flex-direction:column;min-height:100vh}.admin-page-wrapper .app-header{flex-shrink:0}.admin-page-wrapper .admin-page{flex:1 1}.header-actions{align-items:center;display:flex;gap:10px}.admin-link:hover{background-color:#5a52e0!important}.panel-group{background-color:#fff;box-shadow:0 4px 6px #0000001a;box-sizing:border-box;height:100%;width:100%}.panel{display:flex;flex-direction:column;overflow:hidden}.resize-handle{background-color:#e0e0e0;border-left:1px solid #d0d0d0;border-right:1px solid #d0d0d0;cursor:col-resize;position:relative;transition:background-color .2s ease;width:4px}.resize-handle:hover{background-color:#007bff}.resize-handle:before{background-color:#999;border-radius:1px;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:2px}.resize-handle:hover:before{background-color:#fff}.resize-handle-horizontal{background-color:#e0e0e0;border-bottom:1px solid #d0d0d0;border-top:1px solid #d0d0d0;cursor:row-resize;height:4px;position:relative;transition:background-color .2s ease}.resize-handle-horizontal:hover{background-color:#007bff}.resize-handle-horizontal:before{background-color:#999;border-radius:1px;content:"";height:2px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.resize-handle-horizontal:hover:before{background-color:#fff}.notes-section{box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:20px}.ai-section,.right-panel-group{height:100%;width:100%}.ai-section{padding:20px;position:relative}.ai-section,.streaming-only-layout{box-sizing:border-box;display:flex;flex-direction:column;overflow:hidden}.streaming-only-layout{height:100%;width:100%}.floating-notes-layout{box-sizing:border-box;height:100%;overflow:hidden;position:relative;width:100%}.floating-notes-background{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.floating-notes-overlay{background-color:#f3e5ab;border-radius:12px;box-shadow:0 8px 24px #0000004d;display:flex;flex-direction:column;max-height:80%;max-width:90%;overflow:hidden;position:absolute;-webkit-user-select:none;user-select:none;width:400px;z-index:10}.floating-notes-header{align-items:center;background-color:#0000001a;border-bottom:1px solid #0000001a;cursor:grab;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.floating-notes-header:active{cursor:grabbing}.floating-notes-header span:first-child{color:#333;font-size:14px;font-weight:600}.drag-hint{color:#666;font-size:11px;font-style:italic}.floating-notes-content{flex:1 1;min-height:0;overflow-y:auto;padding:0}.floating-notes-content .sticky-notes{border-radius:0;box-shadow:none;height:100%;padding:16px}.floating-stream-layout{box-sizing:border-box;height:100%;overflow:hidden;position:relative;width:100%}.floating-stream-background{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.floating-stream-overlay{background-color:#1a1a1a;border-radius:12px;box-shadow:0 8px 24px #00000080;display:flex;flex-direction:column;max-height:80%;max-width:90%;overflow:hidden;position:absolute;-webkit-user-select:none;user-select:none;width:600px;z-index:10}.floating-stream-header{align-items:center;background-color:#0000004d;border-bottom:1px solid #ffffff1a;cursor:grab;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.floating-stream-header:active{cursor:grabbing}.floating-stream-header span:first-child{color:#fff;font-size:14px;font-weight:600}.floating-stream-content{flex:1 1;min-height:0;overflow:hidden;padding:0}.floating-stream-content .webcam-container-wrapper{height:100%;padding:0}
/*# sourceMappingURL=main.7409f551.css.map*/