*{box-sizing:border-box;margin:0;padding:0}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow:hidden;background:#000!important;color:#fff;width:100vw;height:100vh}body.auth-page{overflow:auto;background:transparent;color:#333}body.settings-page,body.dashboard-page{overflow:auto;background:var(--bg-primary, #121212)!important;color:var(--text-primary, #E0E0E0)!important;height:auto;min-height:100vh}html{background:#000!important;width:100%;height:100%}html:has(body.settings-page),html:has(body.dashboard-page){background:var(--bg-primary, #121212)!important;height:auto;overflow:auto}.camera-video{position:fixed;top:0;left:0;width:100vw;height:100vh;object-fit:cover;z-index:1;background:#000;display:block;min-width:100%;min-height:100%;transition:transform .3s ease}.camera-video.flipped{transform:scaleX(-1)}.pinch-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:100;background:transparent}.snap-grid-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5;opacity:.6;display:none}.ar-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:2;pointer-events:none}.sidebar-toggle,.sidebar,.sidebar-overlay,.camera-status{pointer-events:auto}#ar-scene{width:100%;height:100%;position:absolute;top:0;left:0}#ar-scene{background:transparent!important}#ar-scene canvas{background:transparent!important;display:block}.ar-container.hidden{display:none!important}.sidebar-toggle{display:none!important;position:fixed;top:20px;right:20px;width:150px;height:150px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:60px;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 4px 12px #00000026}.hand-menu-toggle{position:fixed;top:20px;left:20px;width:120px;height:60px;background:#14141eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(74,144,226,.4);border-radius:12px;color:#fff;font-size:24px;cursor:pointer;z-index:1001;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 12px #0000004d;pointer-events:auto}.hand-menu-toggle.active{background:#4a90e299;border-color:#4a90e2cc;box-shadow:0 0 20px #4a90e280}.hand-menu-toggle:hover{background:#4a90e24d;transform:scale(1.05)}.hand-menu-toggle:active{transform:scale(.95)}.hand-menu-toggle .toggle-label{font-size:12px;font-weight:600;line-height:1}.hand-menu-toggle .toggle-icon{font-size:28px;line-height:1}.home-button{position:fixed;bottom:20px;left:20px;width:120px;height:60px;background:#14141eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(102,126,234,.4);border-radius:12px;color:#fff;font-size:24px;cursor:pointer;z-index:1001;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 12px #0000004d;pointer-events:auto;text-decoration:none}.home-button:hover{background:#667eea4d;transform:scale(1.05);border-color:#667eea99}.home-button:active{transform:scale(.95)}.home-button .home-label{font-size:12px;font-weight:600;line-height:1}.home-button .home-icon{font-size:28px;line-height:1}.camera-flip-button{position:fixed;bottom:20px;right:20px;width:120px;height:60px;background:#14141eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid rgba(102,126,234,.4);border-radius:12px;color:#fff;font-size:24px;cursor:pointer;z-index:1001;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 12px #0000004d;pointer-events:auto}.camera-flip-button:hover{background:#667eea4d;transform:scale(1.05);border-color:#667eea99}.camera-flip-button:active{transform:scale(.95)}.camera-flip-button .flip-label{font-size:12px;font-weight:600;line-height:1}.camera-flip-button .flip-icon{font-size:28px;line-height:1;transition:transform .3s ease}.camera-flip-button:active .flip-icon{transform:rotate(180deg)}.sidebar-toggle:hover{background:#ffffff40;transform:scale(1.05)}.sidebar-toggle:active{transform:scale(.95)}.toggle-icon{line-height:1}.sidebar{display:none!important;position:fixed;top:0;right:-525px;width:525px;height:100vh;background:#14141466;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-left:1px solid rgba(255,255,255,.2);z-index:2000;transition:right .3s ease;flex-direction:column;box-shadow:-4px 0 20px #0000001a;overflow-y:auto;overflow-x:hidden}.sidebar.open{right:0}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.sidebar-header h2{font-size:24px;font-weight:600;color:#ffffffe6;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.5)}.sidebar-close{background:transparent;border:none;color:#fff;font-size:32px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;line-height:1}.sidebar-close:hover{background:#ffffff1a}.sidebar-nav{flex:1;padding:20px 0;position:relative}.nav-section{margin-bottom:30px;padding:0 20px;position:static}.nav-section h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#fffc;margin-bottom:12px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5)}.nav-item{width:100%;background:#ffffffbf;border:1px solid rgba(255,255,255,.3);color:#222;padding:16px;margin-bottom:8px;border-radius:12px;cursor:grab;display:flex;align-items:center;gap:12px;transition:all .2s ease;text-align:left;font-size:16px;position:relative;box-shadow:0 2px 4px #0000001a}.nav-item:hover{background:#ffffffe6;box-shadow:0 4px 8px #00000026}.nav-item:active{background:#ffffffd9}.nav-item.active{background:#4a90e2d9;border:1px solid rgba(74,144,226,.5);color:#fff}.nav-item.dragging{box-shadow:0 0 12px 4px #1ba0e2;z-index:3000;cursor:grabbing;opacity:.95;transform:scale(1.05)}.nav-icon{font-size:20px;width:24px;text-align:center}.nav-label{flex:1;font-weight:500}.nav-status{font-size:12px;color:#000000b3;padding:4px 8px;background:#0000001a;border-radius:6px;font-weight:600}.nav-item.active .nav-status{background:#ffffff4d;color:#fff}.camera-selector-container{padding:16px;cursor:default}.camera-selector-container .nav-label{color:#fffc;font-weight:500;margin-bottom:8px;display:block}.camera-select{width:100%;padding:10px;background:#ffffffe6;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#222;font-size:14px;cursor:pointer;outline:none;transition:all .2s ease}.camera-select:hover{background:#fff;border-color:#4a90e280}.camera-select:focus{border-color:#4a90e2cc;box-shadow:0 0 0 2px #4a90e233}.sidebar-overlay{display:none!important;position:fixed;top:0;left:0;width:100vw;height:100vh;background:transparent;z-index:1500;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none}.sidebar-overlay.active{opacity:0;visibility:visible;pointer-events:auto}.camera-status{position:fixed;top:20px;left:20px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 16px;border-radius:8px;display:flex;align-items:center;gap:8px;z-index:1000;font-size:14px;border:1px solid rgba(255,255,255,.1)}.status-dot{width:8px;height:8px;border-radius:50%;background:#ff6b6b;animation:pulse 2s infinite}.camera-status.ready .status-dot{background:#51cf66;animation:none}.status-text{color:#ffffffe6;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.sidebar{width:100%;right:-100%}.sidebar-toggle{top:15px;right:15px;width:135px;height:135px;font-size:54px}.camera-status{top:15px;left:15px;padding:10px 12px;font-size:12px}.home-button{bottom:15px;left:15px;width:110px;height:55px}.home-button .home-label{font-size:11px}.home-button .home-icon{font-size:26px}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.captions-container{position:fixed;top:85%;left:50%;transform:translate(-50%);width:90%;max-width:800px;z-index:500;pointer-events:auto;display:flex;justify-content:center;align-items:center;cursor:move;-webkit-user-select:none;user-select:none;transition:left .15s ease-out,top .15s ease-out}.captions-container.dragging{cursor:grabbing;transition:none}.captions-container.speech-bubble{cursor:default;pointer-events:none}.captions-text{background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:16px 24px;border-radius:16px;font-size:20px;font-weight:500;line-height:1.5;text-align:center;box-shadow:0 4px 20px #00000080;border:1px solid rgba(255,255,255,.2);min-height:50px;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease;word-wrap:break-word;max-width:100%;pointer-events:none;position:relative}.captions-container.speech-bubble .captions-text:after{content:"";position:absolute;bottom:-12px;left:50%;transform:translate(-50%);width:0;height:0;border-left:15px solid transparent;border-right:15px solid transparent;border-top:15px solid rgba(0,0,0,.85);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));z-index:501;pointer-events:none}.captions-container.speech-bubble .captions-text{background:#000000e6!important;border:2px solid rgba(255,255,255,.3)!important;box-shadow:0 4px 20px #000000b3!important}.captions-text.show{opacity:1;transform:translateY(0)}.captions-text.interim{color:#ffffffb3;font-style:italic}.captions-text.error{color:#ff6b6b;background:#ff6b6b33;border-color:#ff6b6b4d}.pinch-status{position:fixed;bottom:120px;left:50%;transform:translate(-50%);z-index:1000;pointer-events:none;-webkit-user-select:none;user-select:none}.pinch-type-indicator{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:2500;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity .3s ease}.pinch-type-indicator.hidden{opacity:0;visibility:hidden}.pinch-type-text{background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:12px 24px;border-radius:8px;font-size:18px;font-weight:600;text-align:center;min-width:200px;border:2px solid rgba(255,255,255,.3);box-shadow:0 4px 12px #0000004d}.pinch-type-text.index-pinch{border-color:#4a90e2;background:#4a90e2e6}.pinch-type-text.middle-pinch{border-color:#e2a04a;background:#e2a04ae6}.pinch-text{background:#000000bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:12px 24px;border-radius:8px;font-size:18px;font-weight:600;text-align:center;min-width:150px;border:2px solid rgba(255,255,255,.3);transition:all .3s ease;box-shadow:0 4px 12px #0000004d}.pinch-text.pinched{background:#4caf50d9;border-color:#4caf5080;color:#fff}.pinch-text.not-pinched{background:#000000bf;border-color:#ffffff4d;color:#fff}.pinch-status.hidden{display:none}@media (max-width: 768px){.captions-container{top:85%;bottom:auto;width:95%;padding:0 10px}.captions-text{font-size:16px;padding:12px 20px}.pinch-status{bottom:100px}.pinch-text{font-size:16px;padding:10px 20px;min-width:120px}}button:focus-visible{outline:2px solid #4a90e2;outline-offset:2px}.loading{opacity:.6;pointer-events:none}.face-overlays{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:10;pointer-events:none}.face-tag{position:absolute;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;white-space:nowrap;box-shadow:0 2px 12px #00000080;border:2px solid rgba(74,144,226,.6);pointer-events:auto;z-index:11;transition:opacity .3s ease,transform .3s ease;max-width:200px;line-height:1.4}.face-tag.recognized{border-color:#51cf6699;background:#000000e6}.face-tag.unknown{border-color:#ffc10799;background:#000000e6}.face-tag-name{font-weight:600;font-size:15px;color:#4a90e2;margin-bottom:2px}.face-tag.recognized .face-tag-name{color:#51cf66}.face-tag-notes{font-size:12px;color:#ffffffb3;margin-top:2px;white-space:normal;word-wrap:break-word}.face-tag.hidden{opacity:0;transform:scale(.8);pointer-events:none}.face-registration-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000bf;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.face-registration-modal.show{opacity:1;visibility:visible}.modal-content{background:#1e1e1ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080;border:1px solid rgba(255,255,255,.1);transform:scale(.9);transition:transform .3s ease}.face-registration-modal.show .modal-content{transform:scale(1)}.modal-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:20px;font-weight:600;color:#fff;margin:0}.modal-close{background:transparent;border:none;color:#ffffffb3;font-size:32px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;line-height:1}.modal-close:hover{background:#ffffff1a;color:#fff}.memories-list{display:flex;flex-direction:column;gap:16px}.memory-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;transition:all .2s ease}.memory-item:hover{background:#ffffff14;border-color:#fff3}.memory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.memory-date{font-size:12px;color:#fff9}.memory-summary{font-size:14px;color:#ffffffe6;line-height:1.6;margin-bottom:8px}.memory-transcript{font-size:13px;color:#ffffffb3;line-height:1.5;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);max-height:100px;overflow-y:auto}.memory-transcript-label{font-size:11px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.memories-loading,.memories-empty{text-align:center;padding:40px 20px;color:#ffffffb3}.memories-empty{font-style:italic}.modal-body{padding:24px}.modal-description{color:#fffc;font-size:14px;margin-bottom:20px;line-height:1.6}.form-group{margin-bottom:20px}.form-group label{display:block;color:#fff;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px;color:#fff;font-size:14px;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4a90e2;background:#ffffff26}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff6}.form-group textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:12px;margin-top:24px}.btn-primary,.btn-secondary{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:#4a90e2;color:#fff}.btn-primary:hover{background:#3a7bc8;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#ffffff26;color:#fff}.hand-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:500;pointer-events:none}.hand-menu-quadrilateral{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.quadrilateral-path{fill:#4a90e226;stroke:#4a90e299;stroke-width:.01;stroke-dasharray:.02,.02;transition:all .2s ease}.quadrilateral-path.locked{display:none}.hand-menu-buttons{position:absolute;top:0;left:0;width:100%;height:100%;display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:auto repeat(4,1fr);gap:8px;padding:12px;pointer-events:auto;transform-origin:top left}.hand-menu-button{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(74,144,226,.5);border-radius:8px;color:#222;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 2px 8px #0003;min-height:44px;text-align:center;white-space:nowrap;overflow:hidden;opacity:0;transform:scale(.5);text-overflow:ellipsis}.hand-menu-button:hover{background:#fff;border-color:#4a90e2cc;transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.hand-menu-button:active{transform:scale(.95)}.hand-menu-button.highlighted{background:#4a90e2e6;border-color:#4a90e2;color:#fff;box-shadow:0 0 20px #4a90e299}.hand-menu-button-icon{font-size:18px;line-height:1}.hand-menu-button-label{font-size:13px;font-weight:600}.hand-menu-button.active{background:#4a90e2d9;border-color:#4a90e280;color:#fff}.hand-menu-lock-indicator{background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;text-align:center;margin-bottom:8px;border:2px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000004d;transition:all .3s ease;grid-column:1 / -1;width:100%;opacity:0;transform:scale(.5)}.hand-menu-lock-indicator.locked{background:#51cf66e6;border-color:#51cf66;color:#fff;box-shadow:0 0 15px #51cf6680}.hand-menu-lock-indicator.unlocked{background:#4a90e2e6;border-color:#4a90e2;color:#fff}.hand-menu-unlock-button{background:#ffc107f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:3px solid rgba(255,193,7,1);border-radius:12px;color:#222;padding:16px 24px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #0000004d;min-height:60px;text-align:center;margin-bottom:12px;opacity:0;transform:scale(.5);width:100%;grid-column:1 / -1}.hand-menu-unlock-button:hover{background:#ffc107;transform:scale(1.05);box-shadow:0 6px 16px #0006}.hand-menu-unlock-button:active{transform:scale(.95)}.hand-menu-unlock-button.highlighted{background:#ff9800;border-color:#ff9800;box-shadow:0 0 20px #ff9800cc}.hand-menu-prompt{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:20px 30px;border-radius:12px;font-size:16px;text-align:center;z-index:501;pointer-events:none;border:2px solid rgba(74,144,226,.5);box-shadow:0 4px 20px #00000080}.hand-menu-prompt.hidden{display:none}@media (max-width: 768px){.camera-flip-button{width:100px;height:50px;bottom:15px;right:15px}.camera-flip-button .flip-icon{font-size:24px}.camera-flip-button .flip-label{font-size:11px}}@media (max-width: 768px){.modal-content{width:95%;margin:20px}.modal-header,.modal-body{padding:16px}.face-tag{font-size:12px;padding:6px 10px;max-width:150px}.hand-menu-button{font-size:12px;padding:8px 12px;min-height:40px}.hand-menu-toggle{width:100px;height:50px;font-size:20px}.hand-menu-toggle .toggle-label{font-size:10px}}.face-selection-list{display:flex;flex-direction:column;gap:10px;margin:20px 0}.face-selection-btn{width:100%;padding:15px;margin:5px 0;font-size:16px;text-align:left;background:#f0f0f0;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s;color:#333}.face-selection-btn:hover{background:#e0e0e0;border-color:#4caf50;transform:translate(5px)}.face-selection-btn:active{background:#d0d0d0;transform:translate(2px)}.face-selection-btn strong{display:block;font-size:18px;margin-bottom:5px;color:#2196f3}
