.navbar{position:sticky;top:0;z-index:1000;background-color:var(--color-white);border-bottom:1px solid var(--color-gray-200);box-shadow:var(--shadow-sm);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 var(--space-4);display:flex;align-items:center;justify-content:space-between;height:64px}.navbar-brand{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;transition:opacity var(--transition);text-decoration:none;color:var(--color-primary)}.navbar-brand:hover{opacity:.8}.navbar-logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.navbar-logo svg{transition:transform var(--transition)}.navbar-brand:hover .navbar-logo svg{transform:rotate(-5deg)}.navbar-brand-text{display:flex;flex-direction:column}.navbar-title{font-size:var(--text-xl);font-weight:700;color:var(--color-gray-900);letter-spacing:-.025em;line-height:1}.navbar-subtitle{color:var(--color-gray-500);font-size:var(--text-xs);font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}.navbar-navigation{display:flex;align-items:center;gap:var(--space-4)}.nav-link{text-decoration:none;color:var(--color-gray-600);font-weight:500;font-size:var(--text-sm);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition);position:relative}.nav-link:hover{color:var(--color-primary);background-color:var(--color-gray-50)}.nav-link:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:0;height:2px;background-color:var(--color-primary);transition:width var(--transition)}.nav-link:hover:after{width:calc(100% - var(--space-4))}.nav-button{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;border-radius:var(--radius-md);border:1px solid var(--color-gray-300);background-color:var(--color-white);color:var(--color-gray-700);cursor:pointer;transition:all var(--transition);text-decoration:none;display:inline-block;text-align:center}.nav-button:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-gray-50)}.nav-button.primary{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.nav-button.primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.logout-button{border-color:var(--color-error);color:var(--color-error)}.logout-button:hover{background-color:var(--color-error);color:var(--color-white);border-color:var(--color-error)}.nav-user-menu{display:flex;align-items:center;gap:var(--space-3);margin-left:var(--space-2);padding-left:var(--space-3);border-left:1px solid var(--color-gray-200)}.user-email{font-size:var(--text-sm);color:var(--color-gray-500);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-auth-buttons{display:flex;align-items:center;gap:var(--space-2);margin-left:var(--space-2)}.navbar-toggle{display:none;flex-direction:column;justify-content:space-between;width:24px;height:18px;background:none;border:none;cursor:pointer;padding:0}.toggle-icon{width:100%;height:2px;background-color:var(--color-gray-600);border-radius:1px;transition:transform var(--transition),opacity var(--transition)}.open-icon-1{transform:translateY(8px) rotate(45deg)}.open-icon-2{opacity:0}.open-icon-3{transform:translateY(-8px) rotate(-45deg)}@media(max-width:768px){.navbar-toggle{display:flex}.navbar-navigation{position:fixed;top:64px;left:0;right:0;background-color:var(--color-white);flex-direction:column;align-items:stretch;padding:var(--space-4);border-top:1px solid var(--color-gray-200);box-shadow:var(--shadow-md);transform:translateY(-100%);opacity:0;visibility:hidden;transition:all var(--transition);gap:var(--space-2)}.navbar-navigation.active{transform:translateY(0);opacity:1;visibility:visible}.nav-link{padding:var(--space-3);border-radius:var(--radius-md)}.nav-link:hover{background-color:var(--color-gray-100)}.nav-user-menu{flex-direction:column;align-items:stretch;border-left:none;border-top:1px solid var(--color-gray-200);padding:var(--space-3) 0 0 0;margin:var(--space-2) 0 0 0}.nav-auth-buttons{flex-direction:column;margin-left:0}.user-email{max-width:100%;text-align:center;margin-bottom:var(--space-2)}}.nav-link.active{color:var(--color-primary);font-weight:600}.nav-link.active:after{width:calc(100% - var(--space-4))}.nav-link:focus-visible,.nav-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.admin-indicator{margin-left:4px;font-size:.8em;opacity:.8}.user-info{display:flex;flex-direction:column;align-items:flex-end;margin-right:12px;gap:2px}.user-name{font-size:.875rem;color:#4a5568;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role-badge{font-size:.7rem;background:linear-gradient(135deg,#f6e05e,#d69e2e);color:#744210;padding:2px 8px;border-radius:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:1px solid rgba(214,158,46,.3)}@media(max-width:768px){.nav-user-menu{flex-direction:column;align-items:stretch;gap:8px}.user-info{align-items:center;margin-right:0;margin-bottom:8px}.user-name{max-width:100%;text-align:center}.nav-button.logout-button{width:100%}}.nav-link[href="/admin"]{position:relative;font-weight:600;color:#2d3748}.nav-link[href="/admin"]:hover{color:#4299e1}.nav-link[href="/admin"]:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background:linear-gradient(90deg,#4299e1,#667eea);transform:scaleX(0);transition:transform .3s ease}.nav-link[href="/admin"]:hover:after{transform:scaleX(1)}.nav-link[href="/admin"].active{color:#4299e1;background:#4299e11a;border-radius:6px;padding:6px 12px}.nav-link[href="/admin"].active:after{display:none}.footer{background-color:var(--color-white);border-top:1px solid var(--color-gray-200);padding:var(--space-5) 0;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 var(--space-5)}.footer-content{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);margin-bottom:var(--space-5);justify-items:center;text-align:center}.footer-section-title{color:var(--color-gray-900);font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-3)}.footer-contact-list{list-style:none;margin:0;padding:0}.footer-contact-list li{margin-bottom:var(--space-3)}.footer-nav-list{list-style:none;margin:0;padding:0}.footer-nav-list li{margin-bottom:var(--space-3)}.footer-link{display:flex;align-items:center;gap:var(--space-2);color:var(--color-gray-600);font-size:var(--text-sm);text-decoration:none;transition:color var(--transition)}.footer-link:hover{color:var(--color-primary)}.footer-icon{font-size:var(--text-base);flex-shrink:0}.footer-bottom{border-top:1px solid var(--color-gray-200);padding:var(--space-4) 0;text-align:center}.footer-bottom p{margin:0;color:var(--color-gray-500);font-size:var(--text-sm)}@media(max-width:768px){.footer-content{grid-template-columns:1fr;text-align:center}.footer-link{justify-content:center}.footer-nav-list{display:flex;justify-content:center;gap:var(--space-4)}.footer-nav-list li{margin-bottom:0}}@media(max-width:480px){.footer-link{font-size:var(--text-xs)}.footer-icon{font-size:var(--text-sm)}.footer-nav-list{flex-direction:column;gap:var(--space-2)}}.home{font-family:var(--font-sans);background-color:var(--color-white)}.home>section{width:100%}.hero{min-height:80vh;display:flex;align-items:center;justify-content:center;background-color:var(--hero-bg);padding:var(--space-6) var(--space-5)}.hero-content{max-width:800px;text-align:center;padding:var(--space-6)}.hero-header{margin-bottom:var(--space-5)}.hero-title{color:var(--hero-title-color);font-size:var(--text-2xl);font-weight:var(--font-bold);margin-bottom:var(--space-3);line-height:var(--line-height-tight)}.baskin-emphasis{color:var(--baskin-color);font-size:var(--text-7xl);display:block;font-weight:var(--font-extrabold);letter-spacing:var(--letter-spacing-tight)}.hero-subtitle{color:var(--hero-subtitle-color);font-size:var(--text-xl);font-weight:var(--font-medium);max-width:600px;margin:0 auto}.hero-description{max-width:600px;margin:0 auto var(--space-6)}.hero-description p{color:var(--hero-description-color);font-size:var(--text-lg);line-height:var(--line-height-relaxed)}.hero-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}@media(max-width:768px){.hero{min-height:70vh;padding:var(--space-5) var(--space-4)}.hero-content{padding:var(--space-4)}.hero-title{font-size:var(--text-3xl)}.baskin-emphasis{font-size:var(--text-5xl)}.hero-subtitle{font-size:var(--text-lg)}.hero-description p{font-size:var(--text-base)}.hero-actions{flex-direction:column}}.button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-weight:500;line-height:1.5;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition);text-decoration:none;font-family:var(--font-sans)}.button:disabled{opacity:.5;cursor:not-allowed}.button--primary{background-color:var(--color-primary);color:var(--color-white)}.button--primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.button--secondary{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.button--secondary:hover:not(:disabled){background-color:var(--color-gray-50)}.button--small{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.button--medium{padding:var(--space-3) var(--space-4)}.button--large{padding:var(--space-4) var(--space-5);font-size:var(--text-lg)}.button--full{width:100%}.mediapipe-status-container{margin-bottom:1.5rem}.mediapipe-status{padding:1rem;border-radius:var(--border-radius);text-align:center;display:flex;align-items:center;justify-content:center;gap:.75rem;font-weight:500;margin-bottom:1rem}.mediapipe-status.loading{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:#ffc107}.mediapipe-status.error{background:#dc35451a;border:1px solid rgba(220,53,69,.3);color:#dc3545}.mediapipe-status.ready{background:#28a7451a;border:1px solid rgba(40,167,69,.3);color:#28a745;animation:pulseReady 2s infinite}@keyframes pulseReady{0%{opacity:1}50%{opacity:.8}to{opacity:1}}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--color-primary);animation:spin 1s ease-in-out infinite}.ready-icon,.error-icon{font-size:1.2rem}@media(max-width:768px){.mediapipe-status{padding:.75rem;font-size:var(--text-sm)}.loading-spinner{width:16px;height:16px}}.camera-controls-container{padding:1.5rem;border-radius:var(--border-radius);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(0,216,255,.1);margin-bottom:1.5rem;transition:all .3s ease}.camera-controls-container:hover{box-shadow:var(--hover-shadow);border-color:#00d8ff4d}.camera-controls-row{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.camera-select{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:250px}.camera-select label{color:var(--color-gray-700);font-size:var(--text-sm);font-weight:600}.camera-select select{padding:.75rem 1rem;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);background:var(--color-white);color:var(--color-gray-700);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease}.camera-select select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.camera-select select:disabled{background:var(--color-gray-100);cursor:not-allowed;opacity:.7}.camera-buttons{display:flex;gap:.75rem}.camera-button{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s ease;min-width:120px}.camera-button.start{background:var(--color-primary);color:var(--color-white)}.camera-button.start.ready{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%)}.camera-button.start.disabled{background:var(--color-gray-400);cursor:not-allowed;opacity:.7}.camera-button.start.ready:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--primary-rgb),.3)}.camera-button.stop{background:var(--color-error);color:var(--color-white)}.camera-button.stop:hover{background:var(--color-error-dark);transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--error-rgb),.3)}.fullscreen-button{padding:.75rem 1.5rem;border:1px solid var(--glass-border);border-radius:var(--border-radius-md);background:rgba(var(--primary-rgb),.1);color:var(--text-color);font-size:var(--text-sm);font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s ease;min-width:140px;justify-content:center}.fullscreen-button:hover:not(:disabled){background:rgba(var(--primary-rgb),.2);border-color:var(--accent-color);transform:translateY(-2px)}.fullscreen-button.active{background:#ffc10733;border-color:#ffc107;color:#ffc107}.fullscreen-button:disabled{opacity:.5;cursor:not-allowed}.button-icon{font-size:1.2rem}@media(max-width:768px){.camera-controls-container{padding:1rem}.camera-controls-row{flex-direction:column;align-items:stretch}.camera-select,.camera-select select{width:100%}.camera-buttons,.fullscreen-button{width:100%;justify-content:center}.camera-button{flex:1;min-width:auto}}@media(max-width:480px){.camera-button,.fullscreen-button{padding:.75rem 1rem;font-size:var(--text-xs)}}.camera-preview{margin-top:1.5rem;width:100%}.preview-container{position:relative;width:100%;height:500px;background:var(--color-gray-900);border-radius:var(--border-radius);overflow:hidden;border:1px solid var(--glass-border);box-shadow:0 10px 30px #0000004d}.preview-container.fullscreen-mode{position:fixed;top:0;left:0;width:100vw!important;height:100vh!important;background:#000;z-index:10;border-radius:0;border:none;box-shadow:none}.camera-video{position:absolute;top:0;left:0;width:100%!important;height:100%!important;object-fit:contain!important;background:var(--color-gray-900);z-index:1}.landmarks-canvas{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;z-index:2!important;pointer-events:none!important}.preview-container.fullscreen-mode .camera-video{width:100vw!important;height:100vh!important;object-fit:contain!important}.preview-container.fullscreen-mode .landmarks-canvas{width:100vw!important;height:100vh!important}.preview-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a15b3,#1a1a2eb3);z-index:3}.placeholder-icon{font-size:3rem;margin-bottom:1rem;color:var(--text-secondary)}.preview-placeholder p{margin-top:1rem;color:var(--text-secondary);font-size:var(--text-md);text-align:center;max-width:300px;line-height:1.5}.fullscreen-error{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;background:var(--color-error-light);border:1px solid var(--color-error);border-radius:var(--border-radius-md);color:var(--color-error);font-size:var(--text-sm)}.fullscreen-error .error-icon{font-size:1rem}@media(max-width:992px){.preview-container{height:400px}}@media(max-width:768px){.preview-container{height:300px}}@media(max-width:480px){.preview-container{height:250px}}.mirror-mode-preview-indicator{position:absolute;top:10px;right:10px;background:#000000b3;color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;display:flex;align-items:center;gap:6px;z-index:10;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.2);animation:pulse 2s infinite}@keyframes pulse{0%,to{background:#000000b3}50%{background:#4caf50b3}}.mirror-icon-small{font-size:14px}.preview-container.mirror-mode{position:relative}.preview-container.mirror-mode:before{position:absolute;top:0;left:0;right:0;background:linear-gradient(90deg,#4caf50,#2196f3);color:#fff;text-align:center;padding:8px;font-size:14px;font-weight:700;z-index:10;border-bottom:2px solid white}.camera-video.mirrored{transform:scaleX(-1)}.mirror-mode-indicator{background:linear-gradient(90deg,#4caf50,#2196f3);color:#fff;padding:12px 20px;border-radius:8px;margin:15px 0;display:flex;align-items:center;justify-content:center;gap:10px;font-weight:700;box-shadow:0 4px 12px #4caf504d;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mirror-icon{font-size:20px;animation:spin 4s linear infinite}@keyframes spin{0%{transform:rotateY(0)}50%{transform:rotateY(180deg)}to{transform:rotateY(360deg)}}.mirror-text{font-size:16px;letter-spacing:.5px}.analysis-config-container{padding:1.5rem;border-radius:var(--border-radius);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(0,216,255,.1);margin-bottom:1.5rem;transition:all .3s ease;background:linear-gradient(135deg,rgba(var(--primary-rgb),.05),rgba(var(--secondary-rgb),.05))}.analysis-config-container:hover{box-shadow:var(--hover-shadow);border-color:#00d8ff4d}.config-header{margin-bottom:1.5rem;text-align:center}.config-title{margin:0 0 .5rem;color:var(--color-gray-800);font-size:var(--text-lg);font-weight:600}.config-description{margin:0;color:var(--color-gray-600);font-size:var(--text-sm);line-height:1.5}.config-controls{display:flex;flex-wrap:wrap;gap:1.5rem}.config-label{display:block;margin-bottom:.5rem;color:var(--color-gray-700);font-size:var(--text-sm);font-weight:600}.config-select{width:100%;padding:.75rem 1rem;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);background:var(--color-white);color:var(--color-gray-700);font-size:var(--text-sm);cursor:pointer;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1em}.config-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.config-select:hover{border-color:var(--color-primary-light)}.config-input{width:100%;padding:.75rem 3rem .75rem 1rem;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);background:var(--color-white);color:var(--color-gray-700);font-size:var(--text-sm);transition:all .2s ease}.config-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.config-input:hover{border-color:var(--color-primary-light)}.config-input::placeholder{color:var(--color-gray-400)}.config-unit{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--color-gray-500);font-size:var(--text-sm);pointer-events:none}.config-hint{margin:.25rem 0 0;color:var(--color-gray-500);font-size:var(--text-xs);font-style:italic}@media(max-width:992px){.config-controls{gap:1rem}.config-group{min-width:180px}}@media(max-width:768px){.analysis-config-container{padding:1rem}.config-controls{flex-direction:column;gap:1rem}.config-group{width:100%}}@media(max-width:480px){.config-title{font-size:var(--text-md)}.config-description{font-size:var(--text-xs)}.config-input,.config-select{padding:.65rem .85rem;font-size:var(--text-xs)}}.online-configuration{position:absolute;top:15px;left:50%;transform:translate(-50%);z-index:9999;background:#0f172a80;padding:12px 20px;border-radius:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;width:95%;max-width:1200px;box-sizing:border-box;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0003;transition:all .3s ease}.online-configuration.fullscreen{position:fixed;top:20px;left:50%;transform:translate(-50%);width:95%;max-width:1400px;z-index:99999;background:#0f172a66;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);box-shadow:0 12px 48px #0000004d}.online-configuration:hover{background:#0f172ab3}.online-configuration.fullscreen:hover{background:#0f172a99}.online-configuration-header{display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%}.angle-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 20px;border-radius:8px;min-width:150px;transition:all .3s ease;background:#ffffff0d}.angle-display.left{align-items:flex-start;margin-right:auto}.angle-display.right{align-items:flex-end;margin-left:auto}.angle-display.valgo{border:1px solid rgba(16,185,129,.3);background:#10b98114;box-shadow:0 4px 12px #10b98126}.angle-display.ok{border:1px solid rgba(239,68,68,.3);background:#ef444414;box-shadow:0 4px 12px #ef444426}.angle-label{font-size:.8rem;color:#94a3b8e6;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.angle-value{font-size:1.8rem;font-weight:700;color:#fff;margin:2px 0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.center-controls{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;max-width:400px;min-width:300px;padding:0 20px}.header-title h3{margin:0;font-size:1.1rem;font-weight:600;color:#60a5fae6;white-space:nowrap}.threshold-control{display:flex;align-items:center;justify-content:center;gap:12px;width:100%}.threshold-label{font-size:.8rem;color:#94a3b8cc;font-weight:500;white-space:nowrap}.threshold-slider{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#10b98166,#f59e0b66,#ef444466);border-radius:3px;outline:none;min-width:120px;max-width:200px;cursor:pointer}.threshold-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#ffffffe6;border:2px solid rgba(96,165,250,.7);cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.threshold-slider::-webkit-slider-thumb:hover{transform:scale(1.1);background:#fff;border-color:#60a5fa}.threshold-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#ffffffe6;border:2px solid rgba(96,165,250,.7);cursor:pointer;box-shadow:0 2px 6px #0000004d}.threshold-value{font-weight:500;color:#94a3b8cc;font-size:.8rem;min-width:85px;text-align:center}@media(max-width:1200px){.online-configuration{width:98%;padding:10px 15px}.center-controls{min-width:250px}.angle-display{min-width:130px;padding:10px 15px}.angle-value{font-size:1.6rem}.threshold-value{min-width:75px}}@media(max-width:992px){.online-configuration-header{gap:15px}.angle-value{font-size:1.4rem}.header-title h3{font-size:1rem}.threshold-control{gap:10px}.threshold-label,.threshold-value{font-size:.75rem}}@media(max-width:768px){.online-configuration{padding:8px 12px;top:10px;width:100%;border-radius:0;max-width:100%;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.online-configuration.fullscreen{top:10px;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.online-configuration-header{flex-direction:column;gap:10px}.angle-display.left,.angle-display.right{margin:0;align-items:center;width:100%;flex-direction:row;justify-content:space-between;padding:8px 12px}.center-controls{order:-1;min-width:100%;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.angle-value{font-size:1.3rem}.threshold-control{flex-direction:column;gap:8px}.threshold-slider{width:100%;max-width:none}}:fullscreen .online-configuration,:-webkit-full-screen .online-configuration,:-moz-full-screen .online-configuration{position:fixed!important;top:20px!important;left:50%!important;transform:translate(-50%)!important;width:95%!important;max-width:1400px!important;z-index:2147483647!important;background:#0f172a66!important;-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;border:1px solid rgba(255,255,255,.15)!important;box-shadow:0 12px 48px #0000004d!important}.fullscreen-tools-vertical{position:fixed;left:10px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:8px;z-index:2147483647!important;padding:10px;background:#0f172ad9;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0006}.tool-btn{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;cursor:pointer;color:#fffc;transition:all .2s ease;position:relative;padding:6px}.visual-overlay{position:fixed;inset:0;z-index:2147483646!important;pointer-events:none}.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:50px 50px;opacity:.6}.vertical-line-container{position:absolute;top:0;bottom:0;left:0;width:0;pointer-events:none;z-index:2147483645}.vertical-line{position:absolute;top:0;bottom:0;left:-1px;width:2px;background:#3b82f6b3;transition:all .2s ease}.vertical-handle{position:absolute;left:-20px;top:50%;transform:translateY(-50%);width:40px;height:60px;background:#0f172af2;border:2px solid rgba(59,130,246,.8);border-radius:8px;cursor:ew-resize;pointer-events:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .2s ease;box-shadow:0 4px 12px #0000004d;z-index:2147483647}.vertical-handle:hover{background:#1e293bf2;border-color:#3b82f6;transform:translateY(-50%) scale(1.05);box-shadow:0 6px 16px #0006}.vertical-handle:active{background:#3b82f633;border-color:#3b82f6;cursor:grabbing}.horizontal-line-container{position:absolute;left:0;right:0;top:0;height:0;pointer-events:none;z-index:2147483645}.horizontal-line{position:absolute;left:0;right:0;top:-1px;height:2px;background:#ef4444b3;transition:all .2s ease}.horizontal-handle{position:absolute;top:-30px;left:50%;transform:translate(-50%);width:60px;height:40px;background:#0f172af2;border:2px solid rgba(239,68,68,.8);border-radius:8px;cursor:ns-resize;pointer-events:auto;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #0000004d;z-index:2147483647}.horizontal-handle:hover{background:#1e293bf2;border-color:#ef4444;transform:translate(-50%) scale(1.05);box-shadow:0 6px 16px #0006}.horizontal-handle:active{background:#ef444433;border-color:#ef4444;cursor:grabbing}.handle-icon{color:#60a5fa;font-size:16px;font-weight:700}.horizontal-handle .handle-icon{color:#ef4444}.handle-percentage{color:#94a3b8;font-size:11px;font-weight:600;font-family:monospace;background:#0000004d;padding:2px 6px;border-radius:4px;min-width:30px;text-align:center}body.dragging-vertical .vertical-line{background:#3b82f6;width:3px;box-shadow:0 0 15px #3b82f680}body.dragging-horizontal .horizontal-line{background:#ef4444;height:3px;box-shadow:0 0 15px #ef444480}.vertical-line-container.dragging{z-index:2147483648!important}.vertical-line-container.dragging .vertical-line{background:#3b82f6;width:3px;box-shadow:0 0 20px #3b82f6b3}.vertical-line-container.dragging .vertical-handle{background:#3b82f64d;border-color:#3b82f6;box-shadow:0 0 20px #3b82f680}.horizontal-line-container.dragging{z-index:2147483648!important}.horizontal-line-container.dragging .horizontal-line{background:#ef4444;height:3px;box-shadow:0 0 20px #ef4444b3}.horizontal-line-container.dragging .horizontal-handle{background:#ef44444d;border-color:#ef4444;box-shadow:0 0 20px #ef444480}.vertical-handle:before{content:"";position:absolute;inset:5px -15px;background:linear-gradient(to right,transparent 0%,rgba(59,130,246,.1) 50%,transparent 100%);pointer-events:none;opacity:0;transition:opacity .2s ease}.horizontal-handle:before{content:"";position:absolute;inset:-15px 5px;background:linear-gradient(to bottom,transparent 0%,rgba(239,68,68,.1) 50%,transparent 100%);pointer-events:none;opacity:0;transition:opacity .2s ease}.vertical-handle:hover:before,.horizontal-handle:hover:before{opacity:1}@keyframes pulse{0%{box-shadow:0 0 #3b82f6b3}70%{box-shadow:0 0 0 10px #3b82f600}to{box-shadow:0 0 #3b82f600}}.tool-btn{animation:fadeIn .2s ease}.vertical-handle,.horizontal-handle{animation:fadeIn .3s ease}@media(max-width:768px){.fullscreen-tools-vertical{left:5px;padding:8px;transform:translateY(-50%) scale(.9)}.tool-btn{width:40px;height:40px}.tool-icon{font-size:16px}.vertical-handle{width:36px;height:50px;left:-18px}.horizontal-handle{width:50px;height:36px;top:-25px}.handle-icon{font-size:14px}.handle-percentage{font-size:10px;padding:1px 4px}.grid-overlay{background-size:30px 30px}}.vertical-handle:after,.horizontal-handle:after{content:attr(title);position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#0f172af2;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 12px #0000004d;z-index:2147483649}.vertical-handle:hover:after,.horizontal-handle:hover:after{opacity:1}.landmarks-tools-vertical{position:fixed;right:10px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;z-index:2147483647!important;padding:8px;background:#0f172ad9;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0006;max-height:90vh;width:170px;overflow-y:auto;overflow-x:hidden}.landmarks-tools-vertical::-webkit-scrollbar{width:2px}.landmarks-tools-vertical::-webkit-scrollbar-track{background:transparent}.landmarks-tools-vertical::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:1px}.landmarks-tools-vertical::-webkit-scrollbar-thumb:hover{background:#3b82f680}.tool-btn{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;cursor:pointer;color:#fffc;transition:all .2s ease;position:relative;padding:6px;align-self:center}.tool-btn:hover{background:#ffffff26;border-color:#ffffff40;transform:translateY(-1px)}.tool-btn.active{background:#3b82f640;border-color:#3b82f680;color:#60a5fa;box-shadow:0 0 12px #3b82f64d}.tool-icon{font-size:18px;margin-bottom:2px}.tool-badge{position:absolute;top:-4px;right:-4px;background:#10b981;color:#fff;font-size:9px;font-weight:600;padding:2px 5px;border-radius:10px;min-width:18px;text-align:center;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 4px #0003}.tool-separator{height:1px;background:#ffffff1a;margin:4px 0;width:100%}.selection-summary{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:6px;padding:6px 8px;margin-bottom:4px}.summary-text{font-size:10px;color:#60a5fa;font-weight:500;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.landmarks-section,.joints-section{margin-bottom:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;padding:0 2px}.section-title{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.section-actions{display:flex;gap:4px}.action-btn{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:3px;cursor:pointer;color:#fff9;font-size:8px;font-weight:700;transition:all .2s ease;padding:0}.action-btn:hover{background:#ffffff1a;color:#ffffffe6;transform:scale(1.1)}.landmarks-selector{display:flex;flex-direction:column;gap:4px}.landmark-btn{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;color:#fffc;transition:all .2s ease;position:relative;width:100%;box-sizing:border-box;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.landmark-btn:hover{background:#ffffff1a;border-color:var(--landmark-color);transform:translate(-2px)}.landmark-btn.active{background:#3b82f626;border-color:var(--landmark-color);box-shadow:0 0 8px var(--landmark-color)}.landmark-icon{font-size:14px;width:20px;text-align:center;flex-shrink:0}.landmark-label{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.landmark-btn.active .landmark-label{color:var(--landmark-color);font-weight:600}.joints-selector{display:flex;flex-direction:column;gap:4px}.joint-btn{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;color:#fffc;transition:all .2s ease;position:relative;width:100%;box-sizing:border-box;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.joint-btn:hover{background:#ffffff1a;border-color:var(--joint-color);transform:translate(-2px)}.joint-btn.active{background:#3b82f626;border-color:var(--joint-color);box-shadow:0 0 8px var(--joint-color)}.joint-icon{font-size:12px;width:16px;text-align:center;flex-shrink:0;color:var(--joint-color)}.joint-label{font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.joint-btn.active .joint-label{color:var(--joint-color);font-weight:600}.selection-indicator{position:absolute;right:6px;width:6px;height:6px;background:var(--landmark-color, var(--joint-color));border-radius:50%;box-shadow:0 0 6px var(--landmark-color, var(--joint-color));flex-shrink:0}.landmark-selection-indicator{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:2147483647!important;animation:slideIn .3s ease;max-width:300px;width:auto}.indicator-content{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#0f172af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;border:1px solid rgba(59,130,246,.3);box-shadow:0 4px 20px #0000004d;min-width:180px}.indicator-icon{font-size:18px;background:#3b82f61a;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid rgba(59,130,246,.2)}.indicator-text{flex:1;min-width:0}.indicator-title{font-size:12px;font-weight:600;color:#60a5fa;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.indicator-hint{font-size:10px;color:#94a3b8;opacity:.8;white-space:nowrap}@keyframes slideIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.tool-btn,.landmark-btn,.joint-btn{animation:fadeIn .2s ease}.landmark-btn.active,.joint-btn.active{animation:pulseBorder 2s infinite}@keyframes pulseBorder{0%{box-shadow:0 0 0 0 var(--landmark-color, var(--joint-color))}70%{box-shadow:0 0 0 4px #3b82f600}to{box-shadow:0 0 #3b82f600}}.landmark-btn:after,.joint-btn:after,.tool-btn:after{content:attr(title);position:absolute;left:auto;right:calc(100% + 10px);top:50%;transform:translateY(-50%);background:#0f172af2;color:#fff;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 12px #0000004d;z-index:2147483649}.tool-btn:after{left:calc(100% + 10px);right:auto}.landmark-btn:hover:after,.joint-btn:hover:after,.tool-btn:hover:after{opacity:1}@media(max-width:768px){.landmarks-tools-vertical{right:5px;padding:6px;transform:translateY(-50%) scale(.9);max-height:85vh;width:150px}.tool-btn{width:36px;height:36px}.tool-icon{font-size:14px}.landmark-btn,.joint-btn{padding:5px 6px}.landmark-icon{font-size:12px;width:16px}.landmark-label,.joint-label{font-size:10px}.joint-icon{font-size:10px;width:14px}.section-title{font-size:9px}.action-btn{width:14px;height:14px;font-size:7px}.summary-text{font-size:9px}.landmark-selection-indicator{top:10px;max-width:250px}.indicator-content{padding:8px 12px;min-width:160px}.indicator-icon{width:28px;height:28px;font-size:16px}.indicator-title{font-size:11px}.indicator-hint{font-size:9px}}@media(prefers-color-scheme:dark){.landmarks-tools-vertical{background:#000000d9;border-color:#ffffff26}.indicator-content{background:#000000e6;border-color:#3b82f666}}.line-boundary-config{position:fixed;left:10px;top:50%;transform:translateY(-50%);z-index:2147483646!important;padding:12px;background:#0f172ad9;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0006;width:320px;max-height:90vh;overflow-y:auto;overflow-x:hidden}.line-boundary-config::-webkit-scrollbar{width:4px}.line-boundary-config::-webkit-scrollbar-track{background:transparent}.line-boundary-config::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:2px}.config-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.header-title{display:flex;align-items:center;gap:8px;margin-bottom:12px}.header-title h3{margin:0;font-size:14px;font-weight:600;color:#60a5fa;text-transform:uppercase;letter-spacing:.5px}.header-icon{font-size:16px}.line-indicators{display:flex;flex-direction:column;gap:8px}.line-indicator{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.line-indicator.vertical{border-left:3px solid #3B82F6}.line-indicator.horizontal{border-left:3px solid #EF4444}.indicator-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.line-indicator.vertical .indicator-dot{color:#3b82f6}.line-indicator.horizontal .indicator-dot{color:#ef4444}.indicator-text{font-size:11px;color:#fffc;font-weight:500}.main-controls{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.tracking-control{background:#ffffff0d;border-radius:8px;padding:10px;border:1px solid rgba(255,255,255,.1)}.tracking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.tracking-toggle{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;color:#fffc;transition:all .2s ease;flex:1}.tracking-toggle:hover:not(:disabled){background:#ffffff26;border-color:#ffffff40;transform:translateY(-1px)}.tracking-toggle.active{background:#3b82f640;border-color:#3b82f680;color:#60a5fa;box-shadow:0 0 12px #3b82f64d}.tracking-toggle:disabled{opacity:.5;cursor:not-allowed}.toggle-icon{font-size:14px}.toggle-label{font-size:12px;font-weight:500;flex:1;text-align:left}.toggle-status{font-size:10px;font-weight:600;background:#10b98133;color:#10b981;padding:2px 6px;border-radius:10px;min-width:28px;text-align:center}.tracking-toggle.active .toggle-status{background:#10b98166}.line-position{display:flex;align-items:center;gap:4px;margin-left:8px}.position-label{font-size:10px;color:#fff9}.position-value{font-size:11px;font-weight:600;color:#60a5fa;font-family:monospace}.tracking-info{padding:6px 8px;background:#0003;border-radius:4px}.info-text{font-size:10px;color:#ffffffb3;line-height:1.3}.sound-control{display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;border-radius:8px;padding:10px;border:1px solid rgba(255,255,255,.1)}.sound-toggle{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;color:#fffc;transition:all .2s ease;flex:1}.sound-toggle:hover{background:#ffffff26;border-color:#ffffff40;transform:translateY(-1px)}.sound-toggle.active{background:#f59e0b40;border-color:#f59e0b80;color:#f59e0b;box-shadow:0 0 12px #f59e0b4d}.sound-icon{font-size:14px}.sound-label{font-size:12px;font-weight:500;flex:1;text-align:left}.sound-status{font-size:10px;font-weight:600;background:#10b98133;color:#10b981;padding:2px 6px;border-radius:10px;min-width:28px;text-align:center}.sound-toggle.active .sound-status{background:#10b98166}.test-sound-btn{padding:6px 12px;background:#3b82f633;border:1px solid rgba(59,130,246,.3);border-radius:6px;color:#60a5fa;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-left:8px}.test-sound-btn:hover{background:#3b82f64d;border-color:#3b82f680;transform:translateY(-1px)}.landmarks-config{margin-top:16px}.config-section-title{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;margin-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.config-section-title span:first-child{font-size:12px;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px}.count-badge{background:#3b82f633;color:#60a5fa;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;min-width:20px;text-align:center}.landmarks-list{display:flex;flex-direction:column;gap:8px}.landmark-config-item{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;transition:all .2s ease}.landmark-config-item:hover{background:#ffffff0d;border-color:var(--landmark-color)}.landmark-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.landmark-info{display:flex;align-items:center;gap:8px}.color-indicator{width:12px;height:12px;border-radius:50%;border:1px solid rgba(255,255,255,.3)}.landmark-name{font-size:12px;font-weight:500;color:#ffffffe6}.landmark-toggles{display:flex;gap:6px}.axis-toggle{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:4px;cursor:pointer;color:#ffffffb3;font-size:10px;transition:all .2s ease}.axis-toggle:hover:not(:disabled){background:#ffffff26;border-color:#ffffff40}.axis-toggle.active{background:#3b82f633;border-color:var(--landmark-color);color:var(--landmark-color)}.axis-toggle:disabled{opacity:.4;cursor:not-allowed}.axis-icon{font-size:10px}.axis-label{font-weight:500}.axis-details{margin-top:8px;padding:8px;background:#0003;border-radius:6px;border-left:3px solid var(--landmark-color)}.axis-details.vertical{border-left-color:#3b82f6}.axis-details.horizontal{border-left-color:#ef4444}.axis-controls{display:flex;flex-direction:column;gap:8px}.control-group{display:flex;align-items:center;gap:8px}.control-label{font-size:10px;color:#ffffffb3;min-width:60px}.direction-buttons,.trigger-buttons{display:flex;gap:6px;flex:1}.direction-btn,.trigger-btn,.sound-toggle-btn{padding:4px 8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#ffffffb3;font-size:10px;cursor:pointer;transition:all .2s ease;flex:1;text-align:center}.direction-btn:hover,.trigger-btn:hover,.sound-toggle-btn:hover:not(:disabled){background:#ffffff26;border-color:#ffffff40}.direction-btn.active,.trigger-btn.active{background:#3b82f64d;border-color:var(--landmark-color);color:var(--landmark-color)}.sound-toggle-btn.active{background:#f59e0b4d;border-color:#f59e0b;color:#f59e0b}.sound-toggle-btn:disabled{opacity:.4;cursor:not-allowed}.config-summary{margin-top:16px;padding:12px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:8px}.summary-title{font-size:11px;font-weight:600;color:#60a5fa;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.summary-content{display:flex;flex-direction:column;gap:6px}.summary-item{display:flex;align-items:center;gap:8px}.summary-icon{font-size:12px;width:16px;text-align:center}.summary-text{font-size:10px;color:#fffc;line-height:1.3}@media(max-width:768px){.line-boundary-config{left:5px;padding:10px;width:280px;transform:translateY(-50%) scale(.95)}.config-header h3{font-size:13px}.landmark-header{flex-direction:column;align-items:flex-start;gap:6px}.landmark-toggles{width:100%;justify-content:space-between}.control-group{flex-direction:column;align-items:flex-start;gap:4px}.control-label{min-width:auto}.direction-buttons,.trigger-buttons{width:100%}}@media(prefers-color-scheme:dark){.line-boundary-config{background:#000000d9;border-color:#ffffff26}}.line-indicator.alert-active{background-color:#f003;border-left-color:red}.line-indicator.highlight{background-color:#ffd70033;border-left-color:gold}.line-indicator.highlight .indicator-dot{animation:pulse 1s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}to{transform:scale(1);opacity:1}}.landmark-config-item.highlighted{border:2px solid var(--landmark-color);box-shadow:0 0 10px rgba(var(--landmark-color-rgb, 255, 215, 0),.5);animation:glow 2s infinite alternate}@keyframes glow{0%{box-shadow:0 0 10px rgba(var(--landmark-color-rgb, 255, 215, 0),.5)}to{box-shadow:0 0 20px rgba(var(--landmark-color-rgb, 255, 215, 0),.8)}}.highlight-badge{margin-left:8px;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.axis-toggle .axis-status{margin-left:4px;font-size:.8em;font-weight:700}.tracking-info .info-text{display:flex;justify-content:space-between;align-items:center}.summary-count{margin-left:8px;font-size:.9em;color:#666;font-style:italic}.camera-input-container{position:relative;width:100%;min-height:100vh}.camera-input{width:100%;padding:2rem;max-width:1200px;margin:0 auto;color:var(--text-color);font-family:var(--font-family);background:linear-gradient(135deg,var(--background-color) 0%,var(--secondary-color) 100%);border-radius:var(--border-radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}:fullscreen .camera-input,:-webkit-full-screen .camera-input,:-moz-full-screen .camera-input{max-width:100%;width:100%;height:100vh;padding:0;margin:0;border-radius:0;background:#000;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.permission-prompt,.no-cameras,.initializing-cameras{text-align:center;padding:3rem;background:var(--color-white);border-radius:var(--border-radius-lg);border:2px dashed var(--color-gray-300);margin:2rem 0}.permission-icon,.no-cameras-icon{font-size:3rem;margin-bottom:1rem}.permission-button{margin-top:1.5rem;padding:.75rem 2rem;background:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--border-radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease}.permission-button:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.permission-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner.small{width:16px;height:16px;border-width:2px}.loading-spinner.small.white{border-top-color:var(--color-white)}.valgus-biofeedback-indicator{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:12px;animation:pulse 2s infinite;border-left:4px solid #00ff00}.valgus-biofeedback-indicator .biofeedback-icon{font-size:24px}.valgus-biofeedback-indicator .biofeedback-text{font-weight:700;font-size:1.1rem}@keyframes pulse{0%{box-shadow:0 0 #667eeab3}70%{box-shadow:0 0 0 10px #667eea00}to{box-shadow:0 0 #667eea00}}@media(max-width:992px){.camera-input{padding:1.5rem}}@media(max-width:768px){.camera-input{padding:1rem}}.fullscreen-tools-container.top-left{position:fixed;top:20px;left:20px;z-index:1000;background:#000000b3;border-radius:8px;padding:10px;box-shadow:0 2px 10px #0000004d}@keyframes pulse{0%{transform:scale(1);opacity:.7}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:.7}}.highlighted-landmark{animation:pulse .5s ease-in-out infinite}.landmarks-tools .landmark-item.disabled{opacity:.5;cursor:not-allowed}.fullscreen-tools,.angle-limits-config,.online-configuration,.line-boundary-config,.dynamic-valgus-tools,.landmarks-tools{position:fixed;top:20px;right:20px;z-index:999;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 20px #0006;max-width:350px;max-height:80vh;overflow-y:auto;color:#fff}.fullscreen-tools{top:20px;right:20px}.angle-limits-config{top:20px;right:390px}.online-configuration{top:20px;right:760px}.line-boundary-config{bottom:20px;right:20px;top:auto}.dynamic-valgus-tools,.landmarks-tools{bottom:20px;right:390px;top:auto}@media(max-width:1200px){.fullscreen-tools,.angle-limits-config,.online-configuration,.line-boundary-config,.dynamic-valgus-tools,.landmarks-tools{max-width:300px}.angle-limits-config{right:340px}.online-configuration{right:670px}}@media(max-width:992px){.fullscreen-tools,.angle-limits-config,.online-configuration,.line-boundary-config,.dynamic-valgus-tools,.landmarks-tools{max-width:280px;padding:16px}.angle-limits-config{right:320px}.online-configuration{right:620px}}@media(max-width:768px){.fullscreen-tools,.angle-limits-config,.online-configuration,.line-boundary-config,.dynamic-valgus-tools,.landmarks-tools{position:fixed;inset:auto 20px 20px;max-width:none;width:calc(100% - 40px);max-height:40vh}.angle-limits-config,.online-configuration{bottom:calc(40vh + 30px)}}.hand-tools-overlay{position:fixed;top:20px;right:20px;z-index:1000;background:#000000d9;border-radius:12px;padding:20px;max-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);color:#fff}.hand-angle-display h4{color:#0f8;margin-bottom:10px;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:5px}.angle-group{margin-bottom:15px}.angle-item{display:flex;justify-content:space-between;margin:5px 0;padding:3px 0}.finger-name{text-transform:capitalize;color:#cbd5e0}.angle-value{font-weight:700;color:#4f4}.angle-value.exceeded{color:#f44;animation:pulse 1s infinite}.gesture-badge{background:linear-gradient(135deg,#667eea,#764ba2);padding:10px 15px;border-radius:8px;text-align:center;font-size:1.2rem;font-weight:700;margin-top:10px}@keyframes pulse{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.mediapipe-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:#000000b3;border-radius:8px;color:#fff}.mediapipe-loading .spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.mediapipe-error{padding:15px;background:#ff00001a;border:1px solid #ff0000;border-radius:8px;color:red;text-align:center}.dynamic-valgus-tools-container{position:fixed;bottom:20px;right:20px;width:400px;max-height:80vh;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;z-index:1000;box-shadow:0 8px 32px #0000004d;overflow:hidden;display:flex;flex-direction:column}.dynamic-valgus-tools-header{padding:16px 20px;background:#0009;border-bottom:1px solid rgba(255,255,255,.1)}.dynamic-valgus-tools-header h3{margin:0;font-size:16px;font-weight:600;display:flex;align-items:center;gap:10px}.tools-icon{font-size:18px}.dynamic-valgus-tools-content{flex:1;overflow-y:auto;padding:20px;max-height:calc(80vh - 120px)}.tools-section{margin-bottom:24px}.tools-section:last-child{margin-bottom:0}.section-title{font-size:14px;font-weight:600;margin-bottom:12px;color:#e0e0e0;display:flex;align-items:center;gap:8px}.section-icon{font-size:16px}.tools-grid{display:grid;grid-template-columns:1fr;gap:16px}.tool-control-group{background:#ffffff0d;border-radius:8px;padding:16px;border:1px solid rgba(255,255,255,.05)}.tool-control-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.tool-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;flex:1}.tool-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.tool-toggle-label{font-size:14px;font-weight:500;color:#f0f0f0}.status-indicator{font-size:14px;font-weight:700;padding:2px 8px;border-radius:4px;background:#ffffff1a}.position-display{background:#0000004d;padding:8px 12px;border-radius:6px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.position-label{font-size:12px;color:#aaa}.position-value{font-size:12px;font-family:monospace;color:#4caf50;font-weight:500}.movement-controls{display:flex;flex-direction:column;align-items:center;gap:8px}.movement-row{display:flex;gap:8px;justify-content:center}.movement-btn{width:40px;height:40px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s ease}.movement-btn:hover{background:#fff3;border-color:#ffffff4d}.movement-btn.center{background:#4caf5033;border-color:#4caf504d}.line-adjust-controls{display:flex;gap:8px;margin-top:12px}.adjust-btn{flex:1;padding:8px 12px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.adjust-btn:hover{background:#fff3}.adjust-btn.center{background:#4caf5033}.tool-description{font-size:12px;color:#aaa;margin-top:8px;line-height:1.4}.landmarks-selection,.joints-selection{margin-top:12px}.selection-info{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;background:#0000004d;border-radius:6px}.info-label{font-size:12px;color:#aaa}.info-value{font-size:12px;font-weight:500;color:#4caf50}.max-selected-hint{font-size:10px;color:#ff9800;background:#ff98001a;padding:2px 6px;border-radius:4px}.landmarks-grid,.joints-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.landmark-btn,.joint-btn{padding:8px 12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#e0e0e0;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:12px;transition:all .2s ease}.landmark-btn:hover,.joint-btn:hover{background:#ffffff1a;border-color:#fff3}.landmark-btn.selected,.joint-btn.selected{background:#4caf5033;border-color:#4caf5080;color:#4caf50}.landmark-icon,.joint-icon{font-size:14px}.landmark-name,.joint-name{flex:1;text-align:left}.dynamic-valgus-tools-footer{padding:12px 20px;background:#0009;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:8px}.footer-info{display:flex;align-items:center;gap:8px}.info-icon{font-size:12px;opacity:.7}.info-text{font-size:11px;color:#aaa}.dynamic-valgus-tools-content::-webkit-scrollbar{width:6px}.dynamic-valgus-tools-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.dynamic-valgus-tools-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.dynamic-valgus-tools-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.angle-limits-container{background:#0f172af2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:12px;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0006;width:320px;min-height:60px;overflow:hidden;transition:all .3s ease;-webkit-user-select:none;user-select:none;cursor:default}.angle-limits-container.expanded{max-height:80vh;overflow-y:auto}.angle-limits-container.collapsed{height:60px}.angle-limits-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#1e293be6;border-bottom:1px solid rgba(255,255,255,.1);cursor:move;-webkit-user-select:none;user-select:none}.angle-limits-header:hover{background:#1e293b}.expand-toggle{background:transparent;border:none;color:#fffc;font-size:14px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.expand-toggle:hover{background:#ffffff1a;color:#fff}.angle-limits-title{font-size:14px;font-weight:600;color:#e2e8f0;margin:0;flex:1;text-align:center}.header-actions{display:flex;gap:6px}.action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;color:#ffffffb3;font-size:12px;font-weight:700;transition:all .2s ease;padding:0}.action-btn:hover{background:#fff3;color:#fff}.angle-limits-content{padding:12px;display:flex;flex-direction:column;gap:12px;max-height:calc(80vh - 60px);overflow-y:auto}.joint-limit-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;transition:all .3s ease}.joint-limit-item.enabled{border-color:var(--joint-color);box-shadow:0 0 10px #0003}.joint-limit-item.alert-active{animation:alertPulse 1s ease;border-color:#ef4444}@keyframes alertPulse{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 4px #ef44444d}}.joint-limit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.joint-info{display:flex;align-items:center;gap:8px;flex:1}.joint-indicator{width:10px;height:10px;border-radius:50%;background-color:var(--joint-color);box-shadow:0 0 6px var(--joint-color);flex-shrink:0}.joint-name{font-size:14px;font-weight:600;color:#e2e8f0;flex:1}.current-angle-display{font-size:12px;font-weight:700;color:#60a5fa;background:#3b82f61a;padding:2px 6px;border-radius:4px;border:1px solid rgba(59,130,246,.3);min-width:40px;text-align:center}.joint-actions{display:flex;gap:6px;flex-shrink:0}.toggle-btn{padding:4px 10px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#ffffffb3;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:40px}.toggle-btn.active{background:#3b82f64d;border-color:#3b82f680;color:#60a5fa}.toggle-btn:hover{transform:translateY(-1px)}.sound-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#ffffffb3;font-size:12px;cursor:pointer;transition:all .2s ease;padding:0}.sound-btn.active{background:#10b9814d;border-color:#10b98180;color:#10b981}.sound-btn:hover{transform:scale(1.1)}.angle-range-container{display:flex;flex-direction:column;gap:8px}.double-slider-container{position:relative;margin:10px 0}.slider-track{position:relative;height:20px;display:flex;align-items:center}.slider{position:absolute;width:100%;height:6px;background:transparent;-webkit-appearance:none;appearance:none;pointer-events:none;z-index:3;margin:0;padding:0}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--slider-color);cursor:pointer;pointer-events:all;border:2px solid white;box-shadow:0 2px 8px #0000004d;transition:all .2s ease;z-index:4}.slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 12px #0006}.min-slider::-webkit-slider-thumb{background:var(--slider-color)}.max-slider::-webkit-slider-thumb{background:var(--slider-color)}.slider-range-visual{position:absolute;width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.range-track{position:absolute;height:100%;border-radius:3px;opacity:.6;transition:all .3s ease}.slider-values{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding:0 5px}.min-value,.max-value{font-size:12px;font-weight:600;color:#94a3b8;min-width:30px;text-align:center}.range-separator{color:#94a3b8;font-weight:700}.current-angle-indicator{position:relative;height:30px;margin-top:5px}.angle-marker-line{position:absolute;top:0;bottom:0;width:2px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center}.angle-marker{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 2px 6px #0000004d;z-index:2}.angle-tooltip{position:absolute;top:-25px;background:#000000e6;color:#fff;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap;opacity:0;transform:translate(-50%);transition:opacity .2s ease;pointer-events:none}.angle-marker-line:hover .angle-tooltip{opacity:1}.angle-status{text-align:center;margin-top:8px}.status-text{font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px;display:inline-block;transition:all .3s ease}.status-text.nodata{color:#94a3b8;background:#94a3b81a}.status-text.below{color:#f97316;background:#f973161a;animation:statusPulse 2s infinite}.status-text.above{color:#f43f5e;background:#f43f5e1a;animation:statusPulse 2s infinite}.status-text.within{color:#22c55e;background:#22c55e1a}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.7}}.limits-summary{margin-top:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.summary-item{display:flex;flex-direction:column;align-items:center;gap:2px}.summary-label{font-size:10px;color:#94a3b8;text-align:center}.summary-value{font-size:14px;font-weight:700;color:#e2e8f0}.summary-value.within{color:#22c55e}.summary-value.alert{color:#ef4444;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.angle-limits-content::-webkit-scrollbar{width:4px}.angle-limits-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:2px}.angle-limits-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.angle-limits-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.angle-limits-container{width:300px;inset:auto 10px 10px!important}.angle-limits-container.expanded{max-height:60vh}.joint-info{flex-wrap:wrap;gap:4px}.current-angle-display{font-size:11px;padding:1px 4px;min-width:35px}}.instructions-container{width:100%;margin:0 0 var(--space-4) 0}.instructions-toggle{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease;font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-gray-800);box-shadow:var(--shadow-sm)}.instructions-toggle:hover{border-color:var(--color-primary);background:var(--color-gray-50);box-shadow:var(--shadow-md)}.instructions-toggle:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.instructions-toggle-content{display:flex;align-items:center;gap:var(--space-2);flex:1;text-align:left}.toggle-icon{font-size:var(--text-lg);flex-shrink:0;line-height:1}.toggle-text{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.toggle-arrow{font-size:var(--text-sm);color:var(--color-gray-500);transition:transform .2s ease;flex-shrink:0;line-height:1}.instructions-toggle[aria-expanded=true] .toggle-arrow{transform:rotate(180deg);color:var(--color-gray-700)}.instructions-dropdown{width:100%;margin-top:var(--space-2);background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.instructions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4);padding:var(--space-4);max-height:400px;overflow-y:auto}.instruction-section{background:var(--color-gray-50);border-radius:var(--radius-md);padding:var(--space-3);border:1px solid var(--color-gray-200);text-align:left}.section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-gray-900);margin:0 0 var(--space-3) 0;padding-bottom:var(--space-2);border-bottom:1px solid var(--color-gray-200);line-height:var(--line-height-tight);text-align:left}.section-items{display:flex;flex-direction:column;gap:var(--space-2);text-align:left}.instruction-item{font-size:var(--text-sm);color:var(--color-gray-700);line-height:var(--line-height-relaxed);padding:var(--space-1) 0;position:relative;padding-left:var(--space-4);text-align:left}.instruction-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;background:var(--color-primary);border-radius:50%;opacity:.6}.instructions-footer{padding:var(--space-3) var(--space-4);background:var(--color-blue-50);border-top:1px solid var(--color-gray-200);text-align:left}.footer-text{font-size:var(--text-sm);color:var(--color-gray-700);margin:0;line-height:var(--line-height-relaxed);display:flex;align-items:flex-start;gap:var(--space-2);text-align:left}.footer-icon{font-size:var(--text-base);line-height:1;flex-shrink:0}.instruction-section,.section-title,.section-items,.instruction-item,.instructions-footer,.footer-text{text-align:left!important}@media(max-width:1024px){.instructions-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-3);padding:var(--space-3)}}@media(max-width:768px){.instructions-container{margin-bottom:var(--space-3)}.instructions-toggle{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.toggle-icon{font-size:var(--text-base)}.instructions-grid{grid-template-columns:1fr;gap:var(--space-3);padding:var(--space-3);max-height:350px}.instruction-section{padding:var(--space-2)}.instruction-item{padding-left:var(--space-3)}.instructions-footer{padding:var(--space-2) var(--space-3)}}@media(max-width:480px){.instructions-toggle{padding:var(--space-2)}.instructions-toggle-content{gap:var(--space-1)}.instructions-grid{padding:var(--space-2);max-height:300px}.instruction-item:before{width:4px;height:4px}}.instructions-grid>*,.instruction-section>*{text-align:left}.tools-sidebar{position:fixed;left:0;top:0;z-index:1000;background:#000000e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:0 0 12px;border:1px solid rgba(255,255,255,.15);border-top:none;border-left:none;box-shadow:0 4px 20px #0006;display:flex;flex-direction:column;align-items:center;transition:all .3s ease;overflow:hidden;padding:0}.tools-sidebar.visible{height:auto}.tools-sidebar.hidden{height:40px}.toggle-btn{background:#ffffff1a;border:none;border-bottom:1px solid rgba(255,255,255,.15);color:#fff;width:100%;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s ease;padding:0;margin:0}.toggle-btn:hover{background:#fff3}.sidebar-content{padding:16px;width:100%;box-sizing:border-box}.tools-list{display:flex;flex-direction:column;gap:12px;align-items:center;width:100%}.tool-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:relative;padding:0}.tool-button:hover{background:#ffffff1a;transform:translateY(-2px);border-color:#fff3}.tool-button:hover:after{content:attr(title);position:absolute;left:60px;top:50%;transform:translateY(-50%);background:#000000f2;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:1001;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 12px #0000004d;pointer-events:none}.tool-button.active{background:#3b82f64d;border-color:#3b82f680;box-shadow:0 0 0 1px #3b82f680,0 4px 8px #3b82f633}.tool-button.active:hover{background:#3b82f666}.icon-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.icon{font-size:22px;color:#fff;transition:transform .2s ease}.tool-button:hover .icon{transform:scale(1.1)}.tool-button.active .icon{color:#93c5fd}.active-dot{position:absolute;top:-4px;right:-4px;width:10px;height:10px;background:#3b82f6;border-radius:50%;border:2px solid rgba(0,0,0,.9);box-shadow:0 0 6px #3b82f6cc}.tools-sidebar.hidden .sidebar-content{display:none}@media(max-width:768px){.tools-sidebar{border-radius:0 0 12px}.tool-button:hover:after{left:auto;right:60px}}@media(max-width:480px){.tools-sidebar{background:#000000f2}.tool-button{width:44px;height:44px}.icon{font-size:20px}}.grid-configuration{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:2147483647!important;background:#0f172af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:8px 16px;box-shadow:0 8px 32px #0006;min-width:300px;transition:all .3s ease}.grid-configuration.minimized{padding:8px 16px}.grid-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.grid-title{display:flex;align-items:center;gap:8px;color:#ffffffe6;font-size:14px;font-weight:500}.grid-icon{font-size:16px}.grid-label{opacity:.9}.grid-header-controls{display:flex;gap:6px}.minimize-btn,.close-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fffc;cursor:pointer;transition:all .2s ease;font-size:12px}.minimize-btn:hover,.close-btn:hover{background:#ffffff26;transform:scale(1.1)}.close-btn{background:#ef444433;border-color:#ef444466}.close-btn:hover{background:#ef44444d}.grid-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.grid-control.compact{display:flex;align-items:center;gap:8px}.grid-control.compact label{color:#ffffffb3;font-size:11px;font-weight:500;min-width:50px}.compact-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffe6;cursor:pointer;transition:all .2s ease;font-size:12px}.compact-btn:hover{background:#ffffff1f;border-color:#ffffff40}.compact-btn.active{background:#3b82f64d;border-color:#3b82f699}.compact-color-buttons{display:flex;gap:6px}.compact-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.3)}.compact-color.light{background:linear-gradient(135deg,#fff,#f0f0f0)}.compact-color.dark{background:linear-gradient(135deg,#1f2937,#111827)}.compact-spacing{display:flex;align-items:center;gap:6px}.value-display{min-width:40px;text-align:center;color:#ffffffe6;font-family:monospace;font-size:11px;font-weight:600;background:#0000004d;padding:2px 6px;border-radius:4px}.compact-opacity{display:flex;align-items:center;gap:8px;min-width:120px}.compact-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#ffffff1a,#fffc);border-radius:2px;outline:none}.compact-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#60a5fa;cursor:pointer;border:2px solid rgba(255,255,255,.8)}.compact-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#60a5fa;cursor:pointer;border:2px solid rgba(255,255,255,.8)}.compact-btn.reset:hover{background:#3b82f633;transform:rotate(180deg)}@media(max-width:768px){.grid-configuration{bottom:10px;left:10px;right:10px;transform:none;min-width:auto;padding:8px 12px}.grid-controls{gap:12px}.grid-control.compact label{min-width:40px;font-size:10px}.compact-opacity{min-width:100px}.value-display{min-width:30px;font-size:10px;padding:1px 4px}}@media(max-width:480px){.grid-configuration{padding:6px 10px}.grid-controls{gap:8px;justify-content:center}.grid-control.compact{flex-direction:column;gap:4px}.grid-control.compact label{min-width:auto}}.scanner-button-container{position:fixed;bottom:20px;right:20px;z-index:10000;display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:auto}.scanner-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;box-shadow:0 4px 15px #667eea66;transition:all .3s ease}.scanner-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.scanner-button:disabled{opacity:.6;cursor:not-allowed}.scanner-button.scanning{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #f5576cb3}70%{box-shadow:0 0 0 10px #f5576c00}to{box-shadow:0 0 #f5576c00}}.scanner-icon{font-size:18px}.scanner-spinner{width:16px;height:16px;border:2px solid #ffffff;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}.scanner-progress-bar{width:200px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.scanner-progress-fill{height:100%;background:linear-gradient(90deg,#0f0,#0ff);border-radius:3px;transition:width .3s ease}.fullscreen .scanner-button-container{bottom:40px;right:40px}.fullscreen .scanner-button{padding:16px 32px;font-size:16px}.fullscreen .scanner-spinner{width:20px;height:20px}.fullscreen .scanner-progress-bar{width:300px;height:8px}.postural-results-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:9999}.postural-results-modal{background:#0f172a;border-radius:16px;width:95%;max-width:1400px;max-height:90vh;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 25px 50px -12px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{margin:0;color:#fff;font-size:24px;font-weight:600;letter-spacing:-.5px}.close-button{background:none;border:none;color:#94a3b8;font-size:24px;cursor:pointer;padding:8px;line-height:1}.close-button:hover{color:#fff}.modal-content{display:flex;height:calc(90vh - 80px);overflow:hidden}.visualization-section{flex:2;padding:30px;display:flex;flex-direction:column;background:#1e293b}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:#0f172a;border-radius:12px;border:2px solid rgba(255,255,255,.1);padding:20px}.analysis-canvas{display:block;max-width:100%;max-height:100%;object-fit:contain}.visualization-summary{display:flex;gap:15px;margin-top:20px;justify-content:center}.summary-badge{background:#3b82f626;border:1px solid rgba(59,130,246,.3);padding:12px 20px;border-radius:12px;color:#93c5fd;font-size:15px;font-weight:500;display:flex;align-items:center;gap:10px;min-width:160px;justify-content:center}.badge-icon{font-size:18px}.metrics-section-minimal{flex:1;padding:30px;overflow-y:auto;background:#0f172a;display:flex;flex-direction:column;gap:25px}.metrics-section-minimal::-webkit-scrollbar{width:6px}.metrics-section-minimal::-webkit-scrollbar-track{background:transparent}.metrics-section-minimal::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.overall-score-minimal{display:flex;align-items:center;gap:25px;padding:25px;background:#ffffff08;border-radius:16px;border:1px solid rgba(255,255,255,.05)}.score-circle{width:120px;height:120px;border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}.score-inner{width:100px;height:100px;background:#0f172a;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}.score-number{font-size:36px;font-weight:700;color:#fff;line-height:1}.score-label{font-size:16px;color:#94a3b8;margin-top:4px}.score-details h3{margin:0 0 15px;color:#fff;font-size:20px;font-weight:600}.score-breakdown{display:flex;flex-direction:column;gap:10px}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05)}.breakdown-item:last-child{border-bottom:none}.breakdown-item span:first-child{color:#94a3b8;font-size:14px}.breakdown-value{color:#10b981;font-weight:600;font-size:16px}.breakdown-value:contains("✗"){color:#ef4444}.essential-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.metric-card-minimal{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;transition:all .2s ease}.metric-card-minimal:hover{border-color:#3b82f633;transform:translateY(-2px)}.metric-icon{font-size:24px;width:50px;height:50px;background:#ffffff0d;border-radius:10px;display:flex;align-items:center;justify-content:center}.metric-content{flex:1}.metric-content h4{margin:0 0 8px;color:#fff;font-size:15px;font-weight:600}.metric-values-minimal{display:flex;flex-direction:column;gap:6px}.metric-value{display:flex;justify-content:space-between;font-size:13px}.metric-value span:first-child{color:#94a3b8}.metric-value span:last-child{color:#fff;font-weight:500}.metric-value span.warning{color:#ef4444;font-weight:600}.additional-details{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:12px;overflow:hidden}.additional-details summary{padding:20px;color:#94a3b8;cursor:pointer;list-style:none;display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500}.additional-details summary::-webkit-details-marker{display:none}.additional-details[open] summary{border-bottom:1px solid rgba(255,255,255,.05);color:#fff}.details-content{padding:20px;display:flex;flex-direction:column;gap:20px}.detail-group h5{margin:0 0 12px;color:#cbd5e1;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-item{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:#94a3b8;border-bottom:1px solid rgba(255,255,255,.03)}.detail-item:last-child{border-bottom:none}.modal-actions-minimal{display:flex;gap:12px;margin-top:auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.05)}.btn-close-minimal,.btn-export-minimal{flex:1;padding:14px 20px;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;border:none;transition:all .2s ease}.btn-close-minimal{background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.1)}.btn-close-minimal:hover{background:#ffffff14;color:#fff}.btn-export-minimal{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.btn-export-minimal:hover{transform:translateY(-2px);box-shadow:0 5px 15px #3b82f64d}@media(max-width:1200px){.modal-content{flex-direction:column;height:auto;max-height:90vh}.visualization-section{flex:none;height:60vh}.metrics-section-minimal{flex:none;height:40vh}.essential-metrics{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.postural-results-modal{width:98%;margin:10px}.modal-header{padding:15px 20px}.modal-header h2{font-size:20px}.essential-metrics{grid-template-columns:repeat(2,1fr)}.overall-score-minimal{flex-direction:column;text-align:center;gap:20px}.score-circle{width:100px;height:100px}.score-inner{width:80px;height:80px}.score-number{font-size:28px}}@media(max-width:480px){.essential-metrics{grid-template-columns:1fr}.modal-actions-minimal{flex-direction:column}}.camera-demo-section{padding:var(--space-8) var(--space-5);background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-white) 100%);border-top:1px solid var(--color-gray-200);border-bottom:1px solid var(--color-gray-200)}.camera-demo-container{max-width:1200px;margin:0 auto}.demo-header{text-align:center;margin-bottom:var(--space-6)}.demo-title{font-size:var(--text-3xl);color:var(--color-gray-900);margin-bottom:var(--space-3);font-weight:var(--font-bold);line-height:var(--line-height-tight)}.demo-subtitle{color:var(--color-gray-600);font-size:var(--text-lg);max-width:600px;margin:0 auto;line-height:var(--line-height-relaxed)}.tool-selector-container{background:var(--color-white);padding:var(--space-5);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200);margin-bottom:var(--space-6)}.tool-selector{max-width:500px;margin:0 auto}.tool-selector-label{display:block;margin-bottom:var(--space-2);color:var(--color-gray-700);font-weight:var(--font-medium);font-size:var(--text-base)}.tool-select{width:100%;padding:var(--space-3);border:2px solid var(--color-gray-300);border-radius:var(--border-radius);font-size:var(--text-base);color:var(--color-gray-800);background:var(--color-white);transition:all .2s ease;margin-bottom:var(--space-3);appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:1em;padding-right:var(--space-8)}.tool-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.tool-select:hover{border-color:var(--color-gray-400)}.tool-description{color:var(--color-gray-600);font-size:var(--text-sm);line-height:var(--line-height-relaxed);padding:var(--space-2);background:var(--color-gray-50);border-radius:var(--border-radius);border-left:3px solid var(--color-primary)}.demo-camera-container{margin-bottom:var(--space-6)}.demo-camera-wrapper{background:var(--color-white);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--color-gray-300)}.demo-instructions{background:var(--color-white);padding:var(--space-5);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-gray-200)}.instructions-title{color:var(--color-gray-800);font-size:var(--text-xl);margin-bottom:var(--space-4);font-weight:var(--font-semibold)}.instructions-list{padding-left:var(--space-4);color:var(--color-gray-700);margin-bottom:var(--space-4)}.instructions-list li{margin-bottom:var(--space-2);line-height:var(--line-height-relaxed);padding-left:var(--space-2)}.instructions-list li:last-child{margin-bottom:0}.demo-note{padding:var(--space-4);background:var(--color-blue-50);border-left:4px solid var(--color-primary);border-radius:var(--border-radius)}.note-text{color:var(--color-gray-700);font-size:var(--text-sm);line-height:var(--line-height-relaxed);margin:0}.register-link{color:var(--color-primary);font-weight:var(--font-semibold);text-decoration:none;margin-left:var(--space-1);transition:color .2s ease}.register-link:hover{color:var(--color-primary-dark);text-decoration:underline}@media(max-width:992px){.camera-demo-section{padding:var(--space-6) var(--space-4)}.camera-demo-container{padding:0}.tool-selector-container,.demo-instructions{padding:var(--space-4)}}@media(max-width:768px){.demo-title{font-size:var(--text-2xl)}.demo-subtitle{font-size:var(--text-base)}.instructions-title{font-size:var(--text-lg)}.tool-selector-container,.demo-instructions{padding:var(--space-3)}.tool-select{padding:var(--space-2);font-size:var(--text-sm)}.instructions-list{padding-left:var(--space-3)}.demo-note{padding:var(--space-3)}}.camera-input-hands-container{width:100%;max-width:1200px;margin:0 auto;padding:20px}.camera-input-hands{background-color:#f5f5f5;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 12px #0000001a}.mediapipe-status{margin-bottom:15px;font-size:14px;color:#333}.status-ready{color:#4caf50;font-weight:700}.status-loading{color:#ff9800;font-weight:700}.status-error{color:#f44336;font-weight:700}.camera-controls{display:flex;gap:10px;margin-bottom:15px;align-items:center;flex-wrap:wrap}.camera-controls select{padding:8px 12px;border-radius:6px;border:1px solid #ddd;background-color:#fff;font-size:14px;min-width:200px}.camera-controls select:disabled{opacity:.6;cursor:not-allowed}.start-button,.stop-button,.fullscreen-button,.toggle-angles-button{padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px}.start-button{background-color:#4caf50;color:#fff}.start-button:disabled{background-color:#ccc;cursor:not-allowed}.start-button:not(:disabled):hover{background-color:#45a049}.stop-button{background-color:#f44336;color:#fff}.stop-button:hover{background-color:#d32f2f}.fullscreen-button{background-color:#2196f3;color:#fff}.fullscreen-button:hover{background-color:#1976d2}.toggle-angles-button{background-color:#555;color:#fff}.toggle-angles-button:hover{background-color:#666}.toggle-angles-button.active{background-color:#4caf50}.no-cameras{padding:15px;background-color:#ffebee;border-radius:6px;color:#c62828;text-align:center;margin-bottom:15px}.hand-selection{display:flex;gap:10px;margin-top:15px}.hand-button{padding:10px 20px;border-radius:6px;border:2px solid #ddd;background-color:#fff;cursor:pointer;font-size:14px;transition:all .3s ease;flex:1;display:flex;align-items:center;justify-content:center;gap:8px}.hand-button:hover:not(:disabled){border-color:#2196f3;background-color:#f0f8ff}.hand-button.active{border-color:#4caf50;background-color:#e8f5e9;font-weight:700}.hand-button:disabled{opacity:.5;cursor:not-allowed}.preview-container{width:100%;height:500px;background-color:#000;position:relative;border-radius:12px;overflow:hidden;margin-top:20px;box-shadow:0 8px 24px #0000004d}.preview-container video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);display:block}.preview-container canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}@media(max-width:768px){.camera-input-hands-container{padding:10px}.camera-controls{flex-direction:column;align-items:stretch}.camera-controls select{width:100%;min-width:unset}.hand-selection{flex-direction:column}.preview-container{height:400px}}@media(max-width:480px){.preview-container{height:300px}.camera-input-hands{padding:15px}}.hand-info-overlay{position:absolute;bottom:10px;left:10px;background-color:#000000d9;color:#fff;padding:10px;border-radius:8px;font-size:11px;font-family:monospace;max-width:250px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d;z-index:100}.hand-status-row{display:flex;align-items:center;margin-bottom:12px;gap:8px}.hand-status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hand-status-text{font-size:10px;font-weight:500;flex-grow:1}.frame-count{font-size:9px;opacity:.8}.angles-container{display:flex;flex-direction:column;gap:10px}.angle-item{display:flex;flex-direction:column;gap:4px}.angle-value-row{display:flex;justify-content:space-between;align-items:center}.angle-label{font-size:10px}.angle-value{font-weight:700;font-size:11px;min-width:30px;text-align:right}.slider-row{display:flex;align-items:center;gap:8px;margin-top:2px}.angle-slider{flex-grow:1;height:4px;-webkit-appearance:none;appearance:none;background:#333;border-radius:2px;outline:none;cursor:pointer}.angle-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#4caf50;cursor:pointer}.angle-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#4caf50;cursor:pointer;border:none}.slider-value{font-size:9px;min-width:20px;text-align:right;color:#4caf50;font-weight:700}.camera-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;text-align:center;background-color:#000000b3;padding:20px;border-radius:10px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 24px #00000080;min-width:250px}.camera-icon{font-size:48px;margin-bottom:20px;opacity:.8}.camera-instruction{font-size:16px;margin-bottom:10px;font-weight:500}.camera-status{font-size:12px;margin-top:10px;opacity:.8}.input{margin-bottom:var(--space-4);width:100%}.input-label{display:block;margin-bottom:var(--space-1);font-size:var(--text-sm);font-weight:500;color:var(--color-gray-700)}.input-required{color:var(--color-error);margin-left:var(--space-1)}.input-field{width:100%;padding:var(--space-3);font-size:var(--text-base);line-height:1.5;color:var(--color-gray-900);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color var(--transition);outline:none;font-family:var(--font-sans)}.input-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.input-error{border-color:var(--color-error)}.input-error-message{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-error)}.input-helper{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-gray-500)}.input-wrapper{position:relative;width:100%}.with-toggle .input-field{padding-right:40px}.toggle-password-btn{position:absolute;top:50%;right:12px;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;color:var(--color-gray-600);transition:opacity .2s ease,color .2s ease}.toggle-password-btn:hover{opacity:1}.toggle-password-btn:hover{color:var(--color-gray-900);opacity:1}.toggle-password-btn svg{pointer-events:none}.loader{display:flex;justify-content:center;align-items:center}.loader-spinner{border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.loader-small .loader-spinner{width:24px;height:24px}.loader-medium .loader-spinner{width:40px;height:40px}.loader-large .loader-spinner{width:60px;height:60px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-5);background-color:var(--color-gray-50)}.auth-container{width:100%;max-width:400px;background-color:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-md)}.auth-header{text-align:center;margin-bottom:var(--space-5)}.auth-title{font-size:var(--text-2xl);font-weight:600;color:var(--color-gray-900);margin-bottom:var(--space-2)}.auth-subtitle{color:var(--color-gray-600);font-size:var(--text-base)}.auth-form{margin-bottom:var(--space-5)}.auth-error{color:var(--color-error);background-color:#ef44440d;padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm);text-align:center;border:1px solid rgba(239,68,68,.2)}.auth-form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);font-size:var(--text-sm)}.auth-checkbox{display:flex;align-items:center;gap:var(--space-2);color:var(--color-gray-600);cursor:pointer}.auth-checkbox input{width:16px;height:16px}.auth-link{color:var(--color-primary);text-decoration:none;font-size:var(--text-sm)}.auth-footer{text-align:center;padding-top:var(--space-4);border-top:1px solid var(--color-gray-200)}.auth-footer-text{color:var(--color-gray-600);font-size:var(--text-sm);margin-bottom:var(--space-3)}.auth-back-link{color:var(--color-gray-500);text-decoration:none;font-size:var(--text-sm);display:inline-flex;align-items:center;gap:var(--space-1)}.auth-back-link:hover{color:var(--color-gray-700)}.auth-network-error{background-color:#f59e0b1a;color:var(--color-warning);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);border:1px solid rgba(245,158,11,.3);text-align:center}.auth-network-error p{margin:0;font-weight:500}.auth-network-error-sub{font-size:var(--text-sm);opacity:.9;margin-top:var(--space-1)!important}.auth-error{background-color:#ef44441a;color:var(--color-error);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm);text-align:center;border:1px solid rgba(239,68,68,.2)}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-4)}.auth-loading-text{color:var(--color-gray-600);font-size:var(--text-base)}@media(max-width:640px){.auth-page{padding:0;background-color:var(--color-white)}.auth-container{max-width:100%;border-radius:0;box-shadow:none;border:none;padding:var(--space-4);min-height:100vh}.auth-header{margin-bottom:var(--space-4)}.auth-title{font-size:var(--text-xl)}}@media(max-width:375px){.auth-container{padding:var(--space-3)}}.verification-prompt{background:#fff8e6;border:2px solid #ffd700;border-radius:12px;padding:20px;margin-bottom:24px;animation:slideDown .3s ease}.verification-prompt-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.verification-prompt-title{font-size:1.1rem;font-weight:600;color:#d97706;margin:0}.verification-prompt-message{color:#92400e;font-size:.95rem;line-height:1.5;margin:0 0 16px}.verification-prompt-actions{display:flex;flex-direction:column;gap:12px}.verification-prompt-help{font-size:.85rem;color:#92400e;margin:8px 0 0;text-align:center}.verification-prompt-help .auth-link{color:#d97706;font-weight:500;background:none;border:none;padding:0;cursor:pointer;text-decoration:underline}.verification-prompt-help .auth-link:hover{color:#b45309}.auth-success{background:#d1fae5;border:1px solid #10b981;color:#065f46;padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:.95rem;animation:fadeIn .5s ease}.auth-success p{margin:0;display:flex;align-items:center;gap:8px}.auth-success p:before{content:"✓";font-weight:700;color:#10b981}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.verification-prompt{padding:16px}.verification-prompt-header{flex-direction:column;text-align:center;gap:8px}.verification-prompt-title{font-size:1rem}.verification-prompt-actions{gap:10px}.verification-prompt-actions button{width:100%}}.dashboard-header{margin-bottom:var(--space-6)}.header-main{display:flex;align-items:flex-start;gap:var(--space-4)}.menu-toggle{display:flex;flex-direction:column;gap:4px;background:none;border:none;padding:var(--space-2);cursor:pointer;margin-top:var(--space-1)}.menu-toggle span{width:24px;height:2px;background-color:var(--color-gray-600);border-radius:1px;transition:transform var(--transition)}.header-content{flex:1}.header-content h1{margin:0;font-size:var(--text-2xl);color:var(--color-gray-900);font-weight:700;line-height:1.2}.header-description{margin:var(--space-2) 0 0 0;color:var(--color-gray-600);font-size:var(--text-base);line-height:1.5;max-width:600px}@media(min-width:1024px){.menu-toggle{display:none}}@media(max-width:768px){.header-content h1{font-size:var(--text-xl)}.header-description{font-size:var(--text-sm)}}.tools-grid{margin-bottom:40px}.tools-header{margin-bottom:24px}.tools-header-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:12px}.tools-title{font-size:1.75rem;font-weight:700;color:#2d3748;margin:0}.user-role-display{display:flex;align-items:center;gap:8px}.role-badge{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:2px solid transparent}.role-guest{background:linear-gradient(135deg,#a0aec0,#718096);color:#fff}.role-user{background:linear-gradient(135deg,#48bb78,#38a89d);color:#fff}.role-premium_user{background:linear-gradient(135deg,#9f7aea,#ed64a6);color:#fff}.role-professional{background:linear-gradient(135deg,#4299e1,#667eea);color:#fff}.role-admin{background:linear-gradient(135deg,#f6e05e,#d69e2e);color:#744210}.role-super_admin{background:linear-gradient(135deg,#f56565,#ed8936);color:#fff}.tools-stats{display:flex;gap:16px;flex-wrap:wrap;font-size:.875rem;color:#718096}.tools-available{color:#48bb78;font-weight:500}.tools-blocked{color:#f56565;font-weight:500}.tools-admin-access{background:#d69e2e1a;color:#d69e2e;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid rgba(214,158,46,.3)}.tools-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.tool-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px;text-align:left;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:12px}.tool-card:hover:not(:disabled){border-color:#4299e1;transform:translateY(-4px);box-shadow:0 8px 30px #4299e126}.tool-card:disabled{opacity:.6;cursor:not-allowed}.tool-card-locked{position:relative;opacity:.8}.tool-card-locked:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#00000005,#0000000d);border-radius:10px;pointer-events:none}.tool-card-header{display:flex;flex-direction:column;gap:8px}.tool-icon{position:relative;width:60px;height:60px;border-radius:12px;background:#f7fafc;display:flex;align-items:center;justify-content:center;margin-bottom:8px;border:2px solid #e2e8f0}.tool-icon-emoji{font-size:2rem}.tool-lock-icon{position:absolute;top:-6px;right:-6px;background:#f56565;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;border:2px solid white;box-shadow:0 2px 8px #f565654d}.tool-admin-badge{position:absolute;bottom:-6px;right:-6px;background:#f6e05e;color:#744210;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;border:2px solid white;box-shadow:0 2px 8px #d69e2e4d}.tool-card-header h3{font-size:1.125rem;font-weight:600;color:#2d3748;margin:0;line-height:1.3}.tool-plan-requirement{font-size:.75rem;padding:2px 8px;border-radius:10px;background:#4299e11a;color:#4299e1;font-weight:500;align-self:flex-start}.tool-description{font-size:.875rem;color:#718096;line-height:1.5;flex:1;margin:0}.tool-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #edf2f7}.tool-metadata{display:flex;gap:8px;align-items:center}.tool-category{font-size:.75rem;color:#a0aec0;text-transform:uppercase;letter-spacing:.5px}.tool-difficulty{font-size:.625rem;padding:2px 6px;border-radius:8px;font-weight:600;text-transform:uppercase}.difficulty-basic{background:#48bb781a;color:#48bb78}.difficulty-intermediate{background:#f59e0b1a;color:#f59e0b}.difficulty-advanced{background:#f565651a;color:#f56565}.tool-action{display:flex;align-items:center;gap:4px;color:#4299e1;font-weight:500}.tool-action-text{font-size:.875rem}.tool-arrow{font-size:1rem;transition:transform .2s ease}.tool-card:hover .tool-arrow{transform:translate(4px)}.tool-action-locked{display:flex;align-items:center;gap:4px;color:#a0aec0;font-weight:500}.tool-lock-icon-small{font-size:.75rem}.tools-empty{background:#fff;border:2px dashed #e2e8f0;border-radius:12px;padding:40px;text-align:center}.empty-state{max-width:500px;margin:0 auto}.empty-icon{font-size:3rem;margin-bottom:20px;opacity:.5}.empty-state h3{font-size:1.5rem;color:#2d3748;margin:0 0 12px}.empty-state p{color:#718096;margin-bottom:24px}.current-plan{background:#f7fafc;border-radius:8px;padding:20px;margin-bottom:24px;text-align:left}.current-plan h4{font-size:1rem;color:#2d3748;margin:0 0 8px}.current-plan p{color:#718096;font-size:.875rem;margin-bottom:16px}.plan-features{list-style:none;padding:0;margin:0}.plan-features li{color:#4a5568;font-size:.875rem;padding:4px 0;display:flex;align-items:center;gap:8px}.plan-features li:before{content:"✓";color:#48bb78;font-weight:700}.upgrade-suggestion{background:linear-gradient(135deg,#4299e11a,#9f7aea1a);border:1px solid rgba(66,153,225,.2);border-radius:8px;padding:24px}.upgrade-suggestion h4{font-size:1.125rem;color:#2d3748;margin:0 0 12px}.upgrade-suggestion p{color:#4a5568;margin-bottom:20px}.upgrade-button{background:linear-gradient(135deg,#4299e1,#667eea);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.upgrade-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #4299e14d}.tools-upgrade-info{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-radius:12px;padding:24px;margin-top:32px;border:1px solid #e2e8f0}.upgrade-info-content{max-width:600px}.upgrade-info-content h4{font-size:1.25rem;color:#2d3748;margin:0 0 12px}.upgrade-info-content>p{color:#718096;margin-bottom:20px}.upgrade-action{background:#fff;border-radius:8px;padding:20px;border:1px solid #e2e8f0}.upgrade-action p{color:#4a5568;margin-bottom:16px}.upgrade-features{list-style:none;padding:0;margin:0 0 20px}.upgrade-features li{color:#4a5568;font-size:.875rem;padding:4px 0}.upgrade-cta-button{background:linear-gradient(135deg,#48bb78,#38a89d);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.upgrade-cta-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #48bb784d}@media(max-width:768px){.tools-container{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.tools-title{font-size:1.5rem}.tool-card{padding:16px}.tools-empty{padding:24px}}@media(max-width:480px){.tools-container{grid-template-columns:1fr}.tools-stats{flex-direction:column;gap:8px}}.tool-svg{width:38px;height:38px;stroke:var(--text);fill:none}.dashboard-sidebar{width:280px;background:var(--color-white);border-right:1px solid var(--color-gray-200);position:fixed;top:64px;left:0;bottom:0;z-index:50;transform:translate(-100%);transition:transform .3s ease;display:flex;flex-direction:column;overflow-y:auto}.dashboard-sidebar.open{transform:translate(0)}@media(min-width:1024px){.dashboard-sidebar{position:sticky;top:64px;height:calc(100vh - 64px);transform:translate(0);z-index:30}}.sidebar-header{padding:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.sidebar-header h3{margin:0;color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600}.sidebar-nav{flex:1;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:none;background:none;color:var(--color-gray-700);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition);text-align:left;font-size:var(--text-sm);font-weight:500}.sidebar-item:hover{background:var(--color-gray-100);color:var(--color-gray-900)}.sidebar-item.active{background:var(--color-primary);color:var(--color-white);font-weight:600}.sidebar-item.active:hover{background:var(--color-primary-dark)}.sidebar-icon{font-size:var(--text-base);width:24px;display:flex;align-items:center;justify-content:center}.sidebar-label{flex:1}.sidebar-item-count{background:var(--color-gray-200);color:var(--color-gray-700);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600}.sidebar-item.active .sidebar-item-count{background:#fff3;color:var(--color-white)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-gray-200)}.sidebar-close{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-700);cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:all var(--transition)}.sidebar-close:hover{background:var(--color-gray-200);border-color:var(--color-gray-400)}@media(min-width:1024px){.sidebar-overlay{display:none!important}.sidebar-close{display:none}}.sidebar-item-locked{opacity:.6;cursor:not-allowed}.sidebar-item-locked:hover{background-color:transparent}.sidebar-lock{position:absolute;left:8px;font-size:var(--text-xs)}.sidebar-user-role{margin-top:var(--space-1)}.role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:uppercase}.role-admin{background-color:var(--color-error);color:var(--color-white)}.role-professional{background-color:var(--color-primary);color:var(--color-white)}.role-premium_user{background-color:var(--color-success);color:var(--color-white)}.role-user{background-color:var(--color-gray-400);color:var(--color-white)}.sidebar-upgrade{padding:var(--space-3);background-color:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--space-3);text-align:center;border:1px solid var(--color-gray-200)}.sidebar-upgrade p{color:var(--color-gray-600);font-size:var(--text-sm);margin-bottom:var(--space-2)}.upgrade-button{width:100%;padding:var(--space-2);background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background-color var(--transition)}.upgrade-button:hover{background-color:var(--color-primary-dark)}.input-source-selector{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2);background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin-bottom:var(--space-4);max-width:100%;overflow:hidden}.selector-label{color:var(--color-gray-600);font-size:var(--text-sm);font-weight:500;white-space:nowrap;padding:0 var(--space-2)}.source-tabs{display:flex;gap:1px;background:var(--color-gray-200);border-radius:var(--radius-sm);overflow:hidden;flex:1}.source-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-white);border:none;color:var(--color-gray-600);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.source-tab:hover{background:var(--color-gray-50);color:var(--color-gray-800)}.source-tab.active{background:var(--color-primary);color:var(--color-white);font-weight:500}.tab-icon{font-size:var(--text-base);flex-shrink:0}.tab-title{overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.input-source-selector{flex-direction:column;align-items:stretch;gap:var(--space-2)}.selector-label{text-align:center}.source-tabs{grid-template-columns:repeat(2,1fr);display:grid}}@media(max-width:480px){.tab-title{display:none}.source-tab{justify-content:center}}.video-upload-input{width:100%;max-width:1000px;margin:0 auto;padding:20px;font-family:Segoe UI,system-ui,sans-serif}.upload-header{text-align:center;margin-bottom:30px}.upload-header h4{font-size:1.8rem;color:#333;margin-bottom:8px}.upload-header p{color:#666;font-size:1rem}.upload-area{border:3px dashed #ccc;border-radius:12px;padding:60px 20px;text-align:center;background:#fafafa;cursor:pointer;transition:all .3s ease;margin-bottom:20px}.upload-area:hover{border-color:#4a6cf7;background:#f0f4ff}.file-input{display:none}.upload-placeholder{color:#666}.upload-icon{font-size:48px;margin-bottom:15px}.upload-placeholder p{margin:5px 0;font-size:1.1rem}.upload-hint{font-size:.9rem!important;color:#999}.file-info{background:#f8f9fa;border-radius:10px;padding:20px;margin-bottom:25px;border:1px solid #eaeaea}.file-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:15px}.file-name{font-weight:600;color:#333;font-size:1.1rem;flex:1;min-width:200px}.file-size,.file-type{background:#fff;padding:5px 12px;border-radius:20px;font-size:.9rem;color:#666;border:1px solid #ddd}.upload-button{background:#4a6cf7;color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%}.upload-button:hover:not(:disabled){background:#3a5ce5;transform:translateY(-2px)}.upload-button:disabled{background:#ccc;cursor:not-allowed}.upload-progress{margin-top:15px}.progress-bar{height:8px;background:#eaeaea;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#4a6cf7,#6c8eff);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.9rem;color:#666;text-align:center;display:block}.main-content{display:flex;gap:20px;margin-top:20px}.left-panel{flex:0 0 400px;max-width:400px}@media(max-width:1024px){.main-content{flex-direction:column}.left-panel{flex:1;max-width:100%}}.fullscreen-layout{display:flex;position:fixed;inset:0;background:#000;z-index:10000}.fullscreen-left-panel{flex:0 0 300px;background:#000000e6;border-right:1px solid rgba(255,255,255,.1);padding:20px;overflow-y:auto;z-index:10001}.fullscreen-right-panel{flex:1;position:relative}.left-panel{flex:0 0 350px;max-width:350px;min-width:300px}.right-panel{flex:1;min-width:0}.main-content{display:flex;gap:20px;margin-top:20px;min-height:600px}.pose-controls{margin-top:15px;padding:15px;background:#000000e6;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.pose-toggle-btn{width:100%;padding:12px 20px;background:#4a6cf733;border:2px solid rgba(74,108,247,.4);color:#a5b4fc;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.pose-toggle-btn.active{background:#e74c3c33;border-color:#e74c3c66;color:#ff7979}.pose-toggle-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #4a6cf74d}@media(max-width:1024px){.main-content{flex-direction:column}.left-panel{flex:1;max-width:100%}.fullscreen-layout{flex-direction:column}.fullscreen-left-panel{flex:0 0 auto;max-height:300px;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}}.analysis-config-section{margin-bottom:20px;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.analysis-config-container{padding:20px;border-radius:12px;background:#000000d9;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.analysis-config-container:hover{border-color:#4a6cf74d;box-shadow:0 8px 25px #0003}.config-controls{display:flex;flex-wrap:wrap;gap:20px}.config-group{flex:1;min-width:200px}.config-label{display:block;margin-bottom:8px;color:#ffffffe6;font-size:.9rem;font-weight:500}.config-select{width:100%;padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:#fff;font-size:.9rem;cursor:pointer;transition:all .2s ease}.config-select:focus{outline:none;border-color:#4a6cf7;box-shadow:0 0 0 2px #4a6cf733}.config-select:hover{border-color:#ffffff4d}.config-input-with-unit{position:relative;width:100%}.config-input{width:100%;padding:10px 50px 10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:#fff;font-size:.9rem;transition:all .2s ease}.config-input:focus{outline:none;border-color:#4a6cf7;box-shadow:0 0 0 2px #4a6cf733}.config-input:hover{border-color:#ffffff4d}.config-input::placeholder{color:#fff6}.config-unit{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#fff9;font-size:.85rem;pointer-events:none}.fullscreen-analysis-config{margin-bottom:20px;padding:15px;background:#000c;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.fullscreen-analysis-config h4{margin:0 0 15px;color:#a5b4fc;font-size:1rem;text-align:center}.fullscreen-analysis-config .analysis-config-container{padding:15px;background:#ffffff08}.fullscreen-analysis-config .config-controls{gap:15px}.fullscreen-analysis-config .config-group{min-width:180px}@media(max-width:1024px){.config-controls{gap:15px}.config-group{min-width:180px}}@media(max-width:768px){.analysis-config-section{margin-bottom:15px}.analysis-config-container{padding:15px}.config-controls{flex-direction:column;gap:15px}.config-group{width:100%;min-width:100%}.fullscreen-analysis-config{padding:12px}.fullscreen-analysis-config .config-controls{flex-direction:column}}@media(max-width:480px){.analysis-config-container{padding:12px}.config-label{font-size:.85rem}.config-select,.config-input{padding:8px 10px;font-size:.85rem}.config-input{padding-right:45px}}.video-controls-container{position:absolute;bottom:0;left:0;right:0;background:#000000e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding:8px 20px 12px;z-index:10;pointer-events:auto;display:flex;flex-direction:column;gap:8px;min-height:80px}.progress-row{width:100%;margin-bottom:2px}.progress-slider{width:100%;height:6px;-webkit-appearance:none;background:linear-gradient(to right,#4a6cf74d,#4a6cf7cc);border-radius:3px;outline:none;cursor:pointer;transition:all .2s ease;margin:0}.progress-slider:hover{height:8px}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #4a6cf7;cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.progress-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #4a6cf780}.progress-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #4a6cf7;cursor:pointer;box-shadow:0 2px 6px #0000004d}.controls-row{display:flex;align-items:center;justify-content:space-between;gap:15px;height:40px}.time-display{color:#ffffffe6;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.85rem;padding:5px 10px;border-radius:4px;min-width:70px;text-align:center;white-space:nowrap;flex-shrink:0}.current-time{background:#4a6cf733;border:1px solid rgba(74,108,247,.4)}.total-time{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.control-buttons{display:flex;gap:12px;align-items:center;flex:1;justify-content:center;max-width:250px}.control-btn{display:flex;align-items:center;justify-content:center;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease;width:45px;height:35px;flex-shrink:0}.control-btn:hover{background:#ffffff26;transform:translateY(-1px);box-shadow:0 3px 8px #0003}.control-btn:active{transform:translateY(0)}.btn-icon{font-size:18px;line-height:1}.play-pause-btn{background:#4a6cf740;border-color:#4a6cf766;width:50px;height:40px}.play-pause-btn:hover{background:#4a6cf759}.fullscreen-editor .video-controls-container{padding:6px 25px 10px;background:#000000f2;min-height:75px}.fullscreen-editor .progress-slider{height:5px}.fullscreen-editor .progress-slider:hover{height:7px}.fullscreen-editor .controls-row{height:38px}.fullscreen-editor .control-btn{width:42px;height:33px}.fullscreen-editor .play-pause-btn{width:48px;height:38px}.fullscreen-editor .btn-icon{font-size:17px}.fullscreen-editor .time-display{font-size:.82rem;padding:4px 9px}.video-wrapper .video-controls-container{border-radius:0 0 12px 12px}@media(max-width:768px){.video-controls-container{padding:6px 15px 10px;min-height:70px;gap:6px}.controls-row{height:36px;gap:10px}.time-display{font-size:.8rem;padding:4px 8px;min-width:65px}.control-buttons{gap:10px;max-width:220px}.control-btn{width:40px;height:32px}.play-pause-btn{width:45px;height:36px}.btn-icon{font-size:16px}.fullscreen-editor .video-controls-container{padding:5px 15px 8px}.fullscreen-editor .control-buttons{gap:8px}}@media(max-width:480px){.video-controls-container{padding:5px 12px 8px;min-height:65px}.controls-row{height:32px;gap:8px}.time-display{font-size:.75rem;padding:3px 6px;min-width:60px}.control-buttons{gap:8px;max-width:200px}.control-btn{width:36px;height:28px}.play-pause-btn{width:40px;height:32px}.btn-icon{font-size:15px}@media(max-width:360px){.time-display{font-size:.7rem;padding:2px 4px;min-width:55px}.control-buttons{gap:6px;max-width:180px}.control-btn{width:32px;height:26px}.play-pause-btn{width:36px;height:30px}.btn-icon{font-size:14px}}}.video-controls-container{transition:all .3s ease}.video-controls-container:hover{background:#000000f2}.video-container{background:#1a1a1a;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #0000004d;margin-top:20px;position:relative}.video-controls-header{background:#000c;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.video-info{display:flex;gap:10px;flex-wrap:wrap;color:#fff;font-size:.85rem}.video-info span{background:#ffffff1a;padding:4px 8px;border-radius:4px;white-space:nowrap}.video-actions{display:flex;gap:8px;flex-wrap:wrap}.action-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease;display:flex;align-items:center;gap:5px;white-space:nowrap}.action-btn:hover{background:#fff3;transform:translateY(-1px)}.action-btn.primary{background:#4a6cf74d;border-color:#4a6cf780;color:#a5b4fc}.action-btn.primary:hover{background:#4a6cf766}.video-wrapper{position:relative;overflow:hidden;min-height:300px;background:#000;display:flex;align-items:center;justify-content:center;width:100%}.video-player{width:auto;max-width:100%;height:auto;max-height:100%;display:block;object-fit:contain}.pose-overlay-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.frame-controls{position:absolute;bottom:80px;left:50%;transform:translate(-50%);display:flex;gap:20px;background:#000000b3;padding:10px 20px;border-radius:30px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.frame-btn{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:5px 15px;border-radius:50%;transition:all .2s ease}.frame-btn:hover{background:#fff3;transform:scale(1.1)}.frame-btn.play-pause{font-size:28px}.frame-indicator{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 20px;color:#fff;font-size:.9rem;z-index:10}.frame-position,.time-position{background:#000000b3;padding:5px 10px;border-radius:4px;font-family:monospace}.zoom-hint{background:#4a6cf7e6;padding:5px 15px;border-radius:20px;font-size:.8rem}@media(max-width:768px){.video-info{font-size:.75rem}.action-btn{font-size:.75rem;padding:4px 8px}}.trim-panel{background:#000000f2;padding:25px;border-top:1px solid rgba(255,255,255,.15);border-radius:0 0 12px 12px;box-shadow:0 10px 30px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.trim-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;color:#fff;flex-wrap:wrap;gap:20px}.trim-title{display:flex;align-items:center;gap:15px}.trim-title h3{margin:0;font-size:1.4rem;font-weight:600;color:#fff}.trim-icon{font-size:1.8rem;background:#4a6cf733;padding:10px;border-radius:12px;border:2px solid rgba(74,108,255,.4)}.trim-info{display:flex;flex-direction:column;gap:12px;background:#ffffff14;padding:15px;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.trim-duration{display:flex;align-items:center;gap:10px;font-size:1.1rem}.trim-duration .label{color:#ffffffb3;font-weight:500}.trim-duration .value{background:linear-gradient(135deg,#4a6cf7,#6c8eff);padding:5px 15px;border-radius:20px;font-weight:600;font-family:monospace;color:#fff}.trim-timestamps{display:flex;gap:25px;flex-wrap:wrap}.timestamp{display:flex;align-items:center;gap:8px;font-size:.95rem}.timestamp .label{color:#fff9}.timestamp .value.time{background:#ffffff1a;padding:4px 12px;border-radius:6px;font-family:monospace;font-weight:500;border:1px solid rgba(255,255,255,.2);min-width:85px;text-align:center}.timeline-container{margin:25px 0;padding:15px;background:#00000080;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.timeline{position:relative;height:80px;background:#ffffff0d;border-radius:8px;cursor:pointer;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}.timeline-background{position:absolute;inset:0;background:linear-gradient(90deg,#ffffff08,#ffffff0d,#ffffff08)}.current-time-indicator{position:absolute;top:0;bottom:0;width:2px;transform:translate(-50%);z-index:5;pointer-events:none}.indicator-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;box-shadow:0 0 10px #fffc}.indicator-label{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:3px 10px;border-radius:4px;font-family:monospace;font-size:.85rem;white-space:nowrap;border:1px solid rgba(255,255,255,.3)}.selection-area{position:absolute;top:10px;bottom:10px;background:#4a6cf74d;border:2px solid rgba(74,108,247,.8);border-radius:6px;cursor:move;z-index:2;box-shadow:0 5px 20px #4a6cf74d}.selection-handle{position:absolute;top:0;bottom:0;width:24px;display:flex;align-items:center;justify-content:center;cursor:ew-resize;z-index:3;background:#4a6cf7cc}.selection-handle.left{left:-12px;border-radius:6px 0 0 6px}.selection-handle.right{right:-12px;border-radius:0 6px 6px 0}.handle-icon{color:#fff;font-size:.9rem;opacity:.9}.selection-content{position:absolute;inset:0 24px;display:flex;align-items:center;justify-content:center;pointer-events:none}.selection-duration{background:#000000b3;color:#fff;padding:5px 12px;border-radius:4px;font-family:monospace;font-weight:600;font-size:.9rem;border:1px solid rgba(255,255,255,.3)}.time-markers{position:absolute;top:-25px;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none}.time-marker{display:flex;flex-direction:column;align-items:center}.time-marker.start{transform:translate(-50%)}.time-marker.end{transform:translate(50%)}.marker-label{background:#000c;color:#fff;padding:3px 10px;border-radius:4px;font-family:monospace;font-size:.85rem;white-space:nowrap;border:1px solid rgba(255,255,255,.2)}.precision-controls{display:grid;grid-template-columns:1fr 1fr;gap:25px;margin:30px 0;padding:20px;background:#ffffff0d;border-radius:10px;border:1px solid rgba(255,255,255,.1)}@media(max-width:768px){.precision-controls{grid-template-columns:1fr;gap:15px}}.control-group{display:flex;flex-direction:column;gap:10px}.control-group label{color:#fffc;font-weight:500;font-size:.95rem}.input-with-buttons{display:flex;gap:10px;align-items:center}.precision-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 15px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease;white-space:nowrap}.precision-btn:hover:not(:disabled){background:#fff3;transform:translateY(-1px)}.precision-btn:disabled{opacity:.5;cursor:not-allowed}.precision-input{flex:1;background:#00000080;border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 15px;border-radius:6px;font-family:monospace;font-size:1rem;text-align:center;min-width:0}.precision-input:focus{outline:none;border-color:#4a6cf7;box-shadow:0 0 0 2px #4a6cf74d}.trim-actions{display:flex;gap:15px;margin-top:30px;flex-wrap:wrap}.action-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 25px;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s ease;flex:1;min-width:200px}@media(max-width:768px){.action-btn{min-width:100%}}.preview-btn{background:#ffc10733;border:2px solid rgba(255,193,7,.4);color:gold}.preview-btn:hover{background:#ffc1074d;transform:translateY(-2px);box-shadow:0 5px 15px #ffc10733}.cut-btn{background:linear-gradient(135deg,#4a6cf7,#6c8eff);border:2px solid rgba(74,108,247,.5);color:#fff;position:relative}.cut-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #4a6cf766}.cut-btn:disabled{opacity:.6;cursor:not-allowed}.load-btn{background:#2ecc7133;border:2px solid rgba(46,204,113,.4);color:#2ecc71}.load-btn:hover{background:#2ecc714d;transform:translateY(-2px);box-shadow:0 5px 15px #2ecc7133}.duration-badge{background:#fff3;padding:3px 10px;border-radius:20px;font-size:.85rem;font-weight:500;margin-left:5px}.spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite;margin-right:10px}.keyboard-shortcuts{display:flex;justify-content:center;gap:25px;margin-top:25px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);flex-wrap:wrap}.shortcut-item{display:flex;align-items:center;gap:8px;color:#ffffffb3;font-size:.85rem}.shortcut-item kbd{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);padding:3px 8px;border-radius:4px;font-family:monospace;font-weight:600;min-width:24px;text-align:center}.selection-handle:active,.selection-area:active,.timeline.dragging{cursor:grabbing}.fullscreen-editor{width:100%;height:100%;background:#000;display:flex;flex-direction:column;position:relative}.fullscreen-header{background:#000000e6;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);z-index:10;position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.fullscreen-file-info{display:flex;gap:12px;align-items:center;color:#fff;flex:1}.file-name{font-weight:600;font-size:1rem;color:#a5b4fc;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-time,.file-duration{background:#ffffff1a;padding:3px 8px;border-radius:4px;font-size:.85rem;font-family:monospace}.fullscreen-actions{display:flex;gap:8px}.fullscreen-btn{background:#ffffff14;color:#fff;border:1px solid rgba(255,255,255,.15);padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s ease;display:flex;align-items:center;gap:5px;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fullscreen-btn:hover{background:#ffffff1f;transform:translateY(-1px)}.fullscreen-btn.exit-btn{background:#e74c3c33;border-color:#e74c3c4d;color:#ff7979}.fullscreen-btn.exit-btn:hover{background:#e74c3c40}.fullscreen-video-wrapper{flex:1;position:relative;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden}.fullscreen-video-player{width:auto;max-width:100%;height:auto;max-height:100%;object-fit:contain;position:relative;z-index:1}.fullscreen-info-panel{position:absolute;bottom:80px;left:20px;background:#000000b3;border-radius:8px;padding:12px 16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:9;max-width:300px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.info-section h4{color:#a5b4fc;margin:0 0 10px;font-size:1rem}.info-grid{display:grid;grid-template-columns:1fr;gap:8px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#ffffff0d;border-radius:4px}.info-label{color:#ffffffb3;font-size:.85rem}.info-value{color:#fff;font-weight:500;font-size:.85rem;font-family:monospace}@media(max-width:768px){.fullscreen-header{padding:8px 15px}.file-name{max-width:150px;font-size:.9rem}.file-time,.file-duration{font-size:.8rem;padding:2px 6px}.fullscreen-actions{gap:6px}.fullscreen-btn{padding:5px 10px;font-size:.8rem}.fullscreen-info-panel{left:10px;bottom:70px;max-width:250px}}@media(max-width:480px){.fullscreen-header{flex-direction:column;gap:8px;align-items:flex-start}.fullscreen-file-info,.fullscreen-actions{width:100%;justify-content:space-between}}.pose-capture{display:flex;flex-direction:column;gap:15px;padding:20px;background:#000000d9;color:#fff;border-radius:12px;border:1px solid rgba(255,255,255,.1);height:fit-content;min-width:300px;max-width:350px}.capture-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.capture-header h4{margin:0;font-size:1.2rem;color:#4a6cf7;font-weight:600}.mediapipe-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:500}.mediapipe-status.loading{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:gold}.mediapipe-status.ready{background:#2ecc711a;border:1px solid rgba(46,204,113,.3);color:#2ecc71}.mediapipe-status.error{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);color:#e74c3c}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:gold;border-radius:50%;animation:spin 1s linear infinite}.status-indicator{display:flex;align-items:center;gap:10px;padding:10px 15px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.status-dot{width:10px;height:10px;border-radius:50%;transition:background-color .3s ease}.status-dot.active{background-color:#2ecc71;box-shadow:0 0 10px #2ecc7180}.status-dot.inactive{background-color:#e74c3c}.status-text{font-size:.9rem;color:#fffc}.visibility-controls{padding:15px;background:#ffffff0d;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.visibility-controls h5{margin:0 0 12px;font-size:1rem;color:#ffffffe6;font-weight:500}.visibility-grid{display:grid;grid-template-columns:1fr;gap:8px}.visibility-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:8px 12px;border-radius:6px;transition:all .2s ease}.visibility-item:hover{background:#ffffff0d}.visibility-item input{display:none}.checkmark{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:4px;position:relative;transition:all .2s ease;flex-shrink:0}.visibility-item input:checked+.checkmark{background:#4a6cf7;border-color:#4a6cf7}.visibility-item input:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.label-text{font-size:.9rem;color:#fffc}.pose-info{padding:12px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.info-item:last-child{margin-bottom:0}.info-label{font-size:.9rem;color:#ffffffb3}.info-value{font-size:.9rem;font-weight:500}.info-value.active{color:#2ecc71}.info-value.inactive{color:#e74c3c}@media(max-width:768px){.pose-capture{min-width:100%;max-width:100%}.visibility-grid{grid-template-columns:1fr}}.stream-input{width:100%}.stream-header h4{margin:0 0 var(--space-1) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.stream-header p{margin:0;color:var(--color-gray-600);font-size:var(--text-sm)}.stream-config{margin-top:var(--space-3)}.config-group{margin-bottom:var(--space-4)}.config-group label{display:block;margin-bottom:var(--space-2);color:var(--color-gray-700);font-size:var(--text-sm);font-weight:500}.stream-types{display:flex;gap:var(--space-2)}.stream-type{padding:var(--space-2) var(--space-3);background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-700);font-size:var(--text-xs);font-weight:500;cursor:pointer;transition:all var(--transition)}.stream-type:hover{border-color:var(--color-primary);color:var(--color-primary)}.stream-type.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.stream-url-input{width:100%;padding:var(--space-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-gray-800);transition:border-color var(--transition)}.stream-url-input:focus{outline:none;border-color:var(--color-primary)}.input-hint{margin:var(--space-1) 0 0 0;color:var(--color-gray-500);font-size:var(--text-xs)}.stream-actions{display:flex;gap:var(--space-3);align-items:center;margin-top:var(--space-4)}.stream-button{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition)}.stream-button.test{background:var(--color-gray-100);color:var(--color-gray-700)}.stream-button.test:hover:not(:disabled){background:var(--color-gray-200)}.stream-button.connect{background:var(--color-primary);color:var(--color-white)}.stream-button.connect:hover:not(:disabled){background:var(--color-primary-dark)}.stream-button.disconnect{background:var(--color-error);color:var(--color-white)}.stream-button:disabled{opacity:.5;cursor:not-allowed}.connection-status{display:flex;align-items:center;gap:var(--space-2);color:var(--color-gray-700);font-size:var(--text-sm)}.status-indicator{color:var(--color-success);font-size:var(--text-lg)}.status-indicator.active{color:var(--color-success)}.stream-preview{margin-top:var(--space-4)}.stream-preview h5{margin:0 0 var(--space-2) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.preview-container{padding:var(--space-6);background:var(--color-gray-900);border-radius:var(--radius-md)}.stream-placeholder{text-align:center;color:var(--color-white)}.stream-icon{font-size:2.5rem;margin-bottom:var(--space-2)}.stream-info{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid rgba(255,255,255,.1)}.info-item{display:flex;flex-direction:column;gap:var(--space-1)}.info-item span:first-child{color:#ffffffb3;font-size:var(--text-xs)}.info-item span:last-child{color:var(--color-white);font-size:var(--text-sm);font-weight:500}.info-item .status-active{color:var(--color-success)}.sensor-input{width:100%}.sensor-header h4{margin:0 0 var(--space-1) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.sensor-header p{margin:0;color:var(--color-gray-600);font-size:var(--text-sm)}.sensor-connection{margin-top:var(--space-3)}.connection-methods h5{margin:0 0 var(--space-2) 0;color:var(--color-gray-800);font-size:var(--text-sm);font-weight:600}.method-buttons{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.method-button{padding:var(--space-2) var(--space-3);background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-700);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition)}.method-button:hover{border-color:var(--color-primary);color:var(--color-primary)}.method-button.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.connect-panel{padding:var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.connect-instructions h5{margin:0 0 var(--space-2) 0;color:var(--color-gray-800);font-size:var(--text-sm);font-weight:600}.connect-instructions ol{margin:0;padding-left:var(--space-4);color:var(--color-gray-700);font-size:var(--text-sm);line-height:1.5}.connect-instructions li{margin-bottom:var(--space-1)}.connect-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.sensor-button{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition)}.sensor-button.pair{background:var(--color-gray-100);color:var(--color-gray-700)}.sensor-button.pair:hover{background:var(--color-gray-200)}.sensor-button.connect{background:var(--color-primary);color:var(--color-white)}.sensor-button.connect:hover{background:var(--color-primary-dark)}.connected-panel{padding:var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.connection-status{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-700);font-size:var(--text-sm)}.disconnect-button{margin-left:auto;padding:var(--space-1) var(--space-2);background:var(--color-error);color:var(--color-white);border:none;border-radius:var(--radius-sm);font-size:var(--text-xs);cursor:pointer}.sensor-data h5{margin:0 0 var(--space-3) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.data-grid{display:grid;grid-template-columns:1fr;gap:var(--space-3)}@media(min-width:768px){.data-grid{grid-template-columns:repeat(3,1fr)}}.data-card{padding:var(--space-3);background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.data-card h6{margin:0 0 var(--space-2) 0;color:var(--color-gray-800);font-size:var(--text-sm);font-weight:600}.data-values{display:flex;flex-direction:column;gap:var(--space-2)}.value{display:flex;justify-content:space-between;align-items:center}.axis{color:var(--color-gray-600);font-size:var(--text-xs);font-weight:500}.number{color:var(--color-gray-900);font-size:var(--text-sm);font-weight:600;font-family:Courier New,monospace}.stats{display:flex;flex-direction:column;gap:var(--space-2)}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--color-gray-600);font-size:var(--text-xs)}.stat-value{color:var(--color-gray-900);font-size:var(--text-sm);font-weight:500}.tool-view{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);margin-top:var(--space-4);max-width:100%;overflow:hidden}.tool-view-header{padding:var(--space-4);border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap}.tool-view-title{flex:1;min-width:0}.back-button{background:none;border:none;color:var(--color-gray-600);font-size:var(--text-sm);cursor:pointer;padding:var(--space-1) 0;margin-bottom:var(--space-2);transition:color var(--transition)}.back-button:hover{color:var(--color-primary)}.tool-view-title h1{margin:0 0 var(--space-2) 0;color:var(--color-gray-900);font-size:var(--text-xl);font-weight:700;word-wrap:break-word;overflow-wrap:break-word}.tool-view-description{margin:0;color:var(--color-gray-600);font-size:var(--text-sm);line-height:1.5;max-width:100%;word-wrap:break-word}.tool-view-actions{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.start-button{padding:var(--space-2) var(--space-4);background:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-700);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition)}.start-button.primary{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.start-button.primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.tool-view-content{padding:var(--space-4);max-width:100%;overflow:hidden}.source-section{margin-bottom:var(--space-4);padding:var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);max-width:100%;overflow:hidden}.source-header h4{margin:0 0 var(--space-1) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.source-header p{margin:0;color:var(--color-gray-600);font-size:var(--text-sm)}.source-placeholder{text-align:center;padding:var(--space-4);margin-top:var(--space-3);background:var(--color-white);border-radius:var(--radius-md);border:2px dashed var(--color-gray-300)}.placeholder-icon{font-size:2rem;margin-bottom:var(--space-2)}.source-placeholder p{color:var(--color-gray-500);font-size:var(--text-sm);margin:0}.content-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4);max-width:100%}@media(min-width:768px){.content-grid{grid-template-columns:repeat(2,1fr)}}.info-card{background:var(--color-gray-50);border-radius:var(--radius-lg);padding:var(--space-3);border:1px solid var(--color-gray-200)}.info-card h3{margin:0 0 var(--space-2) 0;color:var(--color-gray-800);font-size:var(--text-base);font-weight:600}.simple-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.simple-list li{color:var(--color-gray-700);font-size:var(--text-sm);padding-left:var(--space-3);position:relative}.simple-list li:before{content:"•";position:absolute;left:0;color:var(--color-primary)}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.metric{text-align:center;padding:var(--space-2);background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.metric-label{color:var(--color-gray-600);font-size:var(--text-xs);margin-bottom:var(--space-1)}.metric-value{color:var(--color-gray-900);font-size:var(--text-base);font-weight:600}@media(max-width:768px){.tool-view-header{padding:var(--space-3);flex-direction:column;gap:var(--space-3)}.tool-view-title h1{font-size:var(--text-lg)}.tool-view-actions{width:100%;justify-content:flex-end}.tool-view-content,.source-section{padding:var(--space-3)}.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.metrics-grid{grid-template-columns:1fr}.tool-view-title h1{font-size:var(--text-base)}.tool-view-description{font-size:var(--text-xs)}}.dashboard{min-height:calc(100vh - 64px);background-color:var(--color-gray-50);display:flex}.dashboard-content{flex:1;padding:var(--space-6);max-width:100%;width:100%;transition:margin-left var(--transition)}@media(min-width:1024px){.dashboard-content{max-width:calc(100% - 280px)}}.sidebar-overlay{position:fixed;inset:64px 0 0;background:#00000080;z-index:40;display:none}@media(max-width:1023px){.sidebar-overlay.open{display:block}}@media(max-width:768px){.dashboard-content{padding:var(--space-4)}}@media(max-width:480px){.dashboard-content{padding:var(--space-3)}}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-primary-50) 100%)}.not-found-content{text-align:center;max-width:500px;width:100%}.not-found-number{font-size:8rem;font-weight:var(--font-weight-bold);color:var(--color-primary-500);display:flex;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-lg);line-height:1}.not-found-zero{position:relative;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.not-found-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--space-md)}.not-found-description{color:var(--color-gray-600);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin-bottom:var(--space-2xl);max-width:400px;margin-left:auto;margin-right:auto}.not-found-actions{display:flex;gap:var(--space-md);justify-content:center;margin-bottom:var(--space-xl);flex-wrap:wrap}.not-found-help{color:var(--color-gray-500);font-size:var(--font-size-sm)}.not-found-link{color:var(--color-primary-500);text-decoration:none;font-weight:var(--font-weight-medium)}.not-found-link:hover{text-decoration:underline}@media(max-width:640px){.not-found-number{font-size:6rem}.not-found-title{font-size:var(--font-size-2xl)}.not-found-description{font-size:var(--font-size-base)}.not-found-actions{flex-direction:column}}.contact{padding:var(--space-6) var(--space-5);background-color:var(--color-white);border-top:1px solid var(--color-gray-100)}.contact-container{max-width:1000px;margin:0 auto}.contact-header{text-align:center;margin-bottom:var(--space-6)}.contact-title{color:var(--color-gray-900);font-size:var(--text-xl);font-weight:600;margin-bottom:var(--space-2)}.contact-subtitle{color:var(--color-gray-600);font-size:var(--text-base);max-width:500px;margin:0 auto}.contact-content{display:grid;gap:var(--space-6)}.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.contact-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);text-decoration:none;transition:all var(--transition)}.contact-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.contact-card-icon{color:var(--color-primary);font-size:var(--text-lg);margin-top:var(--space-1)}.contact-card-content{flex:1}.contact-card-title{color:var(--color-gray-900);font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-1)}.contact-card-value{color:var(--color-gray-600);font-size:var(--text-sm);line-height:1.4}.contact-form{background-color:var(--color-gray-50);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.form-title{color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-4);text-align:center}.form-group{margin-bottom:var(--space-4)}.form-input,.form-textarea{width:100%;padding:var(--space-3);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-gray-900);background-color:var(--color-white);transition:all var(--transition)}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;min-height:120px}.status-message{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm);font-weight:500}.status-message.success{background-color:#10b9811a;color:var(--color-success);border:1px solid rgba(16,185,129,.2)}.status-message.error{background-color:#ef44441a;color:var(--color-error);border:1px solid rgba(239,68,68,.2)}.contact-actions{display:flex;justify-content:center}@media(max-width:768px){.contact{padding:var(--space-5) var(--space-4)}.contact-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.contact-card{flex-direction:column;align-items:center;text-align:center;padding:var(--space-3)}.contact-card-icon{margin-top:0;margin-bottom:var(--space-2)}.contact-form{padding:var(--space-4)}.form-group{margin-bottom:var(--space-3)}}@media(max-width:480px){.contact-grid{grid-template-columns:1fr}}.aviso-legal{background-color:var(--color-white);min-height:calc(100vh - 200px);padding:var(--space-6) 0}.aviso-legal-container{max-width:800px;margin:0 auto;padding:0 var(--space-5)}.aviso-legal-header{text-align:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.aviso-legal-title{color:var(--color-gray-900);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-2);line-height:1.3}.aviso-legal-version{color:var(--color-gray-600);font-size:var(--text-base);font-weight:500}.aviso-legal-content{display:flex;flex-direction:column;gap:var(--space-5)}.aviso-legal-section{margin-bottom:var(--space-4)}.aviso-legal-subtitle{color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-gray-200)}.aviso-legal-text{color:var(--color-gray-700);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-3);text-align:justify}.aviso-legal-text:last-child{margin-bottom:0}.aviso-legal-text a{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color var(--transition)}.aviso-legal-text a:hover{color:var(--color-primary-dark);text-decoration:underline}.aviso-legal-text ul,.aviso-legal-text ol{margin-left:var(--space-4);margin-bottom:var(--space-3)}.aviso-legal-text li{margin-bottom:var(--space-2);line-height:1.6}@media(max-width:768px){.aviso-legal{padding:var(--space-5) 0}.aviso-legal-container{padding:0 var(--space-4)}.aviso-legal-header{margin-bottom:var(--space-5)}.aviso-legal-title{font-size:var(--text-xl)}.aviso-legal-subtitle{font-size:var(--text-base)}.aviso-legal-text{font-size:var(--text-sm);line-height:1.6}}@media(max-width:480px){.aviso-legal{padding:var(--space-4) 0}.aviso-legal-container{padding:0 var(--space-3)}.aviso-legal-title{font-size:var(--text-lg)}.aviso-legal-version{font-size:var(--text-sm)}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:var(--space-4)}.loader{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{color:var(--color-gray-600);font-size:var(--text-base)}.about-me{background-color:var(--color-white);padding:var(--space-6) 0}.about-me-container{max-width:1200px;margin:0 auto;padding:0 var(--space-5)}.about-me-hero{margin-bottom:var(--space-6)}.about-me-profile{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);text-align:center}@media(min-width:768px){.about-me-profile{flex-direction:row;text-align:left;gap:var(--space-6)}}.about-me-image-container{width:200px;height:200px;border-radius:50%;overflow:hidden;border:4px solid var(--color-gray-200);box-shadow:var(--shadow-md)}.about-me-image{width:100%;height:100%;object-fit:cover}.about-me-header{flex:1}.about-me-title{color:var(--color-gray-900);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-2)}.about-me-tagline{color:var(--color-gray-600);font-size:var(--text-base);margin-bottom:var(--space-4);display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;justify-content:center}@media(min-width:768px){.about-me-tagline{justify-content:flex-start}}.about-me-tagline span{white-space:nowrap}.about-me-youtube-button{display:inline-flex;align-items:center;gap:var(--space-2);background-color:var(--color-error);color:var(--color-white);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);text-decoration:none;font-weight:600;font-size:var(--text-base);transition:all var(--transition);border:none;cursor:pointer}.about-me-youtube-button:hover{background-color:#c00;transform:translateY(-2px);box-shadow:var(--shadow-md)}.about-me-content{margin-top:var(--space-6)}.about-me-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}@media(min-width:768px){.about-me-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.about-me-grid{grid-template-columns:repeat(2,1fr)}}.about-me-card{background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);padding:var(--space-5);transition:all var(--transition);height:100%;display:flex;flex-direction:column}.about-me-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.about-me-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.about-me-card-icon{color:var(--color-primary);font-size:var(--text-xl);display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--color-gray-50);border-radius:var(--radius-md)}.about-me-card-title{color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600;margin:0}.about-me-card-content{flex:1}.about-me-text{color:var(--color-gray-700);font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-3)}.about-me-text:last-child{margin-bottom:0}.about-me-text strong{color:var(--color-gray-900);font-weight:600}.about-me-list{list-style-type:none;margin:var(--space-4) 0;padding-left:0}.about-me-list-item{color:var(--color-gray-700);font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-3);padding-left:0;position:relative}.about-me-list-item:before{content:"";color:var(--color-primary);position:absolute;left:0}.about-me-list-item:last-child{margin-bottom:0}.about-me-youtube-section{margin-top:var(--space-4);padding:var(--space-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.about-me-youtube-link{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-error);text-decoration:none;font-weight:600;font-size:var(--text-base);transition:color var(--transition);margin-top:var(--space-2)}.about-me-youtube-link:hover{color:#c00;text-decoration:underline}@media(max-width:768px){.about-me{padding:var(--space-5) 0}.about-me-container{padding:0 var(--space-4)}.about-me-title{font-size:var(--text-xl)}.about-me-card{padding:var(--space-4)}.about-me-card-title{font-size:var(--text-base)}.about-me-text,.about-me-list-item{font-size:var(--text-sm)}}@media(max-width:480px){.about-me{padding:var(--space-4) 0}.about-me-container{padding:0 var(--space-3)}.about-me-image-container{width:150px;height:150px}.about-me-title{font-size:var(--text-lg)}.about-me-tagline{font-size:var(--text-sm);flex-direction:column;gap:var(--space-1)}.about-me-youtube-button{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.about-me-card{padding:var(--space-3)}}.politica-privacidad{background-color:var(--color-white);min-height:calc(100vh - 200px);padding:var(--space-6) 0}.politica-privacidad-container{max-width:800px;margin:0 auto;padding:0 var(--space-5)}.politica-privacidad-header{text-align:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.politica-privacidad-title{color:var(--color-gray-900);font-size:var(--text-2xl);font-weight:600;margin-bottom:var(--space-2);line-height:1.3}.politica-privacidad-version{color:var(--color-gray-600);font-size:var(--text-base);font-weight:500}.politica-privacidad-content{display:flex;flex-direction:column;gap:var(--space-6)}.politica-privacidad-section{margin-bottom:var(--space-4)}.politica-privacidad-subtitle{color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-gray-200)}.politica-privacidad-text{color:var(--color-gray-700);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-3);text-align:justify}.politica-privacidad-text:last-child{margin-bottom:0}.politica-privacidad-list{list-style-type:none;margin-left:0;margin-bottom:var(--space-4);padding-left:0}.politica-privacidad-list-item{color:var(--color-gray-700);font-size:var(--text-base);line-height:1.6;margin-bottom:var(--space-3);padding-left:0;position:relative}.politica-privacidad-list-item:before{content:"–";color:var(--color-primary);font-weight:700;display:inline-block;width:1em;margin-left:-1em;margin-right:.5em}.politica-privacidad-list-item:last-child{margin-bottom:0}.politica-privacidad-link{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color var(--transition)}.politica-privacidad-link:hover{color:var(--color-primary-dark);text-decoration:underline}.politica-privacidad-list-item .politica-privacidad-link{display:inline;margin-left:.25em}@media(max-width:768px){.politica-privacidad{padding:var(--space-5) 0}.politica-privacidad-container{padding:0 var(--space-4)}.politica-privacidad-header{margin-bottom:var(--space-5)}.politica-privacidad-title{font-size:var(--text-xl)}.politica-privacidad-subtitle{font-size:var(--text-base)}.politica-privacidad-text{font-size:var(--text-sm);line-height:1.6;text-align:left}.politica-privacidad-list-item{font-size:var(--text-sm)}.politica-privacidad-list-item:before{margin-right:.25em}}@media(max-width:480px){.politica-privacidad{padding:var(--space-4) 0}.politica-privacidad-container{padding:0 var(--space-3)}.politica-privacidad-title{font-size:var(--text-lg)}.politica-privacidad-version{font-size:var(--text-sm)}.politica-privacidad-list{margin-left:0}.politica-privacidad-list-item{padding-left:var(--space-3)}.politica-privacidad-list-item:before{margin-left:-.75em}}.users-table{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;padding:24px;margin-top:24px}.users-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.users-table-header h3{font-size:1.5rem;font-weight:600;color:#2d3748;margin:0}.users-table-controls{display:flex;gap:12px;align-items:center}.users-table-search{padding:10px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#2d3748;background:#fff;transition:all .3s ease;min-width:250px}.users-table-search:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126}.users-table-search::placeholder{color:#a0aec0}.users-table-loading{text-align:center;padding:60px 20px;color:#718096;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014}.users-table-empty{text-align:center;padding:40px 20px;color:#a0aec0;background:#fff;border-radius:12px;border:2px dashed #e2e8f0}.users-table-empty p{margin:0}.users-table-container{overflow-x:auto;border-radius:8px;border:1px solid #e2e8f0}.users-table-content{width:100%;border-collapse:collapse;min-width:800px}.users-table-content thead{background:#f7fafc}.users-table-content th{padding:16px 20px;text-align:left;font-weight:600;color:#4a5568;border-bottom:2px solid #e2e8f0;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}.users-table-content th:hover{background:#edf2f7}.users-table-content th:after{content:"↕";opacity:.3;margin-left:6px;font-size:.75rem}.users-table-content tbody tr{border-bottom:1px solid #edf2f7;transition:background-color .2s ease}.users-table-content tbody tr:hover{background:#fafafa}.users-table-content td{padding:16px 20px;color:#2d3748;vertical-align:middle}.user-cell{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.user-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.user-info{display:flex;flex-direction:column;gap:4px}.user-info strong{font-weight:500;color:#2d3748;font-size:.875rem}.user-id{font-size:.75rem;color:#a0aec0;font-family:monospace}.user-role{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:capitalize}.role-user{background:#4299e11a;color:#4299e1}.role-admin{background:#ed64a61a;color:#ed64a6}.role-professional{background:#48bb781a;color:#48bb78}.role-editor{background:#f59e0b1a;color:#f59e0b}.user-status{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.verified{background:#48bb781a;color:#48bb78}.unverified{background:#f565651a;color:#f56565}.user-actions{display:flex;gap:8px;align-items:center}.action-button{width:32px;height:32px;border-radius:6px;border:none;background:#f7fafc;color:#4a5568;cursor:pointer;transition:all .2s ease;font-size:.875rem;display:flex;align-items:center;justify-content:center;padding:0}.action-button:hover:not(:disabled){transform:translateY(-1px)}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.action-button.view{color:#4299e1;border:1px solid rgba(66,153,225,.2)}.action-button.view:hover:not(:disabled){background:#4299e11a;box-shadow:0 2px 8px #4299e133}.action-button.resend{color:#9f7aea;border:1px solid rgba(159,122,234,.2)}.action-button.resend:hover:not(:disabled){background:#9f7aea1a;box-shadow:0 2px 8px #9f7aea33}.action-button.reset{color:#ed8936;border:1px solid rgba(237,137,54,.2)}.action-button.reset:hover:not(:disabled){background:#ed89361a;box-shadow:0 2px 8px #ed893633}.action-button.delete{color:#f56565;border:1px solid rgba(245,101,101,.2)}.action-button.delete:hover:not(:disabled){background:#f565651a;box-shadow:0 2px 8px #f5656533}@media(max-width:768px){.users-table{padding:16px;margin-top:16px}.users-table-header{flex-direction:column;align-items:stretch;gap:16px}.users-table-header h3{font-size:1.25rem}.users-table-search{min-width:100%}.users-table-content{min-width:600px}.user-cell{gap:8px}.user-avatar{width:32px;height:32px;font-size:.875rem}.user-info strong{font-size:.8125rem}.user-actions{gap:4px}.action-button{width:28px;height:28px;font-size:.75rem}}@media(max-width:480px){.users-table{padding:12px;border-radius:8px}.users-table-container{border-radius:6px}.users-table-content th,.users-table-content td{padding:12px 16px;font-size:.8125rem}.user-role,.user-status{font-size:.6875rem;padding:3px 8px}}.user-form{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;max-width:800px;margin:0 auto;position:relative;max-height:80vh;overflow-y:auto}.user-form-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10;border-radius:12px 12px 0 0}.user-form-header h3{font-size:1.5rem;font-weight:600;color:#2d3748;margin:0}.user-form-cancel{background:none;border:none;font-size:1.5rem;color:#a0aec0;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0;transition:all .2s ease}.user-form-cancel:hover{background:#f7fafc;color:#4a5568}.user-form-content{padding:32px}.user-form-success{background:#c6f6d5;color:#22543d;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:500}.user-form-success p{margin:0}.user-form-error{background:#fed7d7;color:#822727;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.875rem}.user-form-error p{margin:0}.form-section{margin-bottom:32px}.form-section h4{font-size:1rem;font-weight:600;color:#2d3748;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #edf2f7}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.875rem;font-weight:500;color:#4a5568}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=tel],.form-group select{padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#2d3748;background:#fff;transition:all .3s ease;width:100%;box-sizing:border-box}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=password]:focus,.form-group input[type=tel]:focus,.form-group select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126}.form-group input[type=text]:hover,.form-group input[type=email]:hover,.form-group input[type=password]:hover,.form-group input[type=tel]:hover,.form-group select:hover{border-color:#cbd5e0}.form-group input[type=text]:disabled,.form-group input[type=email]:disabled,.form-group input[type=password]:disabled,.form-group input[type=tel]:disabled,.form-group select:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.form-group input::placeholder{color:#a0aec0}.form-help{font-size:.75rem;color:#a0aec0;margin-top:4px}.checkbox-group{margin-top:8px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.875rem;color:#4a5568;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;border-radius:4px;border:2px solid #cbd5e0;background:#fff;cursor:pointer;transition:all .2s ease}.checkbox-label input[type=checkbox]:checked{background:#4299e1;border-color:#4299e1;position:relative}.checkbox-label input[type=checkbox]:checked:after{content:"✓";color:#fff;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:700}.checkbox-label input[type=checkbox]:disabled{background:#f7fafc;border-color:#e2e8f0;cursor:not-allowed}.checkbox-label span{font-size:.875rem;color:#4a5568}.form-error{color:#f56565;font-size:.75rem;margin-top:4px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0}.form-button{padding:12px 24px;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;border:none;transition:all .3s ease;min-width:120px}.form-button.primary{background:#4299e1;color:#fff}.form-button.primary:hover:not(:disabled){background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 12px #4299e14d}.form-button.primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-button.secondary{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.form-button.secondary:hover:not(:disabled){background:#edf2f7}.form-button.secondary:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.user-form{margin:16px;max-height:70vh}.user-form-header{padding:20px 24px}.user-form-content{padding:24px}.form-grid{grid-template-columns:1fr;gap:16px}.form-button{min-width:auto;padding:10px 20px}}@media(max-width:480px){.user-form-header{padding:16px 20px}.user-form-content{padding:20px}.form-actions{flex-direction:column}.form-button{width:100%}}.user-detail{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;max-width:800px;margin:0 auto;overflow:hidden;display:flex;flex-direction:column;max-height:90vh}.user-detail-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0;position:relative}.user-detail-title{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}.user-detail-title h3{font-size:1.5rem;font-weight:600;margin:0;color:#fff;word-wrap:break-word;overflow:hidden;text-overflow:ellipsis}.user-header-badges{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.user-role{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:capitalize;white-space:nowrap}.role-user{background:#4299e133;color:#4299e1;border:1px solid rgba(66,153,225,.3)}.role-admin{background:#ed64a633;color:#ed64a6;border:1px solid rgba(237,100,166,.3)}.role-professional{background:#48bb7833;color:#48bb78;border:1px solid rgba(72,187,120,.3)}.role-editor{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.user-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:500;white-space:nowrap}.verified{background:#48bb7833;color:#48bb78;border:1px solid rgba(72,187,120,.3)}.unverified{background:#f5656533;color:#f56565;border:1px solid rgba(245,101,101,.3)}.user-detail-close{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .3s ease;flex-shrink:0;margin-left:12px}.user-detail-close:hover{background:#ffffff4d;transform:scale(1.1)}.user-detail-content{padding:24px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:#cbd5e0 transparent}.user-detail-content::-webkit-scrollbar{width:6px}.user-detail-content::-webkit-scrollbar-track{background:transparent}.user-detail-content::-webkit-scrollbar-thumb{background-color:#cbd5e0;border-radius:3px}.user-detail-content::-webkit-scrollbar-thumb:hover{background-color:#a0aec0}.detail-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e2e8f0}.detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-section h4{font-size:1rem;font-weight:600;color:#2d3748;margin:0 0 16px;display:flex;align-items:center;gap:8px}.detail-section h4:before{content:"";display:inline-block;width:4px;height:16px;background:#4299e1;border-radius:2px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.detail-item{display:flex;flex-direction:column;gap:6px;min-width:0}.detail-item label{font-size:.75rem;color:#718096;text-transform:uppercase;letter-spacing:.5px;font-weight:500;display:flex;align-items:center;gap:4px}.detail-item label:after{content:":"}.detail-value{font-size:.875rem;color:#2d3748;font-weight:500;word-break:break-word;overflow-wrap:break-word;line-height:1.4}.detail-input,.detail-select{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#2d3748;background:#fff;transition:all .3s ease;width:100%;box-sizing:border-box;font-family:inherit}.detail-input:focus,.detail-select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126}.detail-input:hover,.detail-select:hover{border-color:#cbd5e0}.detail-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23718096' d='M10.193 3.97a.75.75 0 0 1 1.062 1.062l-4.5 4.5a.75.75 0 0 1-1.062 0l-4.5-4.5a.75.75 0 1 1 1.062-1.062L6 7.938l4.193-4.193z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;padding-right:36px;cursor:pointer}.role-field{position:relative;background:linear-gradient(to right,rgba(66,153,225,.05),transparent);padding:12px;border-radius:8px;border-left:3px solid #4299e1;transition:all .3s ease}.role-field:hover{background:linear-gradient(to right,rgba(66,153,225,.1),transparent)}.role-field label{color:#2b6cb0;font-weight:600}.role-field .detail-select{background-color:#f8fafc;border-color:#bee3f8;font-weight:500}.role-field .detail-select:focus{border-color:#4299e1;background-color:#fff}.detail-status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:capitalize;border:1px solid transparent}.status-active{background:#48bb781a;color:#48bb78;border-color:#48bb784d}.status-inactive{background:#f565651a;color:#f56565;border-color:#f565654d}.status-suspended{background:#f59e0b1a;color:#f59e0b;border-color:#f59e0b4d}.apps-section{background:#f7fafc;border-radius:8px;padding:16px;border:1px solid #e2e8f0}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.app-item{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;transition:all .2s ease}.app-item:hover{border-color:#cbd5e0;box-shadow:0 2px 8px #0000000d}.app-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.875rem;color:#4a5568;-webkit-user-select:none;user-select:none;justify-content:space-between}.app-label input[type=checkbox]{width:18px;height:18px;border-radius:4px;border:2px solid #cbd5e0;background:#fff;cursor:pointer;flex-shrink:0;margin:0;transition:all .2s ease}.app-label input[type=checkbox]:checked{background:#4299e1;border-color:#4299e1;position:relative}.app-label input[type=checkbox]:checked:after{content:"✓";color:#fff;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:700}.app-label span{text-transform:capitalize;font-weight:500;flex:1}.date-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.date-item{background:#f8fafc;border-radius:8px;padding:12px;border:1px solid #e2e8f0}.date-item label{font-size:.75rem;color:#718096;text-transform:uppercase;letter-spacing:.5px;font-weight:500;margin-bottom:4px;display:block}.date-value{font-size:.875rem;color:#2d3748;font-weight:500;font-family:Courier New,monospace}.detail-actions{display:flex;flex-direction:column;gap:16px;margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0}.action-group{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.action-button{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .3s ease;display:flex;align-items:center;gap:6px;white-space:nowrap;min-width:140px;justify-content:center}.action-button.primary{background:#4299e1;color:#fff;border:1px solid #4299e1}.action-button.primary:hover:not(:disabled){background:#3182ce;border-color:#3182ce;transform:translateY(-1px);box-shadow:0 4px 12px #4299e14d}.action-button.secondary{background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.action-button.secondary:hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0}.action-button.danger{background:#f7fafc;color:#f56565;border:1px solid #fed7d7}.action-button.danger:hover:not(:disabled){background:#fff5f5;border-color:#feb2b2;transform:translateY(-1px)}.action-button:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.action-button:not(.primary):not(.secondary):not(.danger){background:#f7fafc;color:#4a5568;border:1px solid #e2e8f0}.action-button:not(.primary):not(.secondary):not(.danger):hover:not(:disabled){background:#edf2f7;border-color:#cbd5e0}.edit-mode-indicator{background:#feebc8;color:#744210;padding:8px 12px;border-radius:6px;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:8px;margin-bottom:16px;border:1px solid #fbd38d}.edit-mode-indicator:before{content:"✏️"}.edit-mode .role-field{background:linear-gradient(to right,#4299e11a,#fff);border-color:#4299e1;box-shadow:0 0 0 1px #4299e133}.edit-mode .role-field .detail-select{background:#fff;border-color:#4299e1}@media(max-width:768px){.user-detail{margin:16px;max-height:85vh}.user-detail-header{padding:16px 20px;flex-direction:column;gap:12px}.user-detail-title h3{font-size:1.25rem}.user-detail-close{position:absolute;top:16px;right:16px;margin:0}.user-detail-content{padding:20px}.detail-grid{grid-template-columns:1fr;gap:12px}.apps-grid{grid-template-columns:repeat(2,1fr)}.date-grid{grid-template-columns:1fr}.action-group{width:100%;flex-direction:column}.action-button{width:100%;min-width:0}.role-field{padding:10px}}@media(max-width:480px){.user-detail{margin:8px;border-radius:8px}.user-detail-content{padding:16px}.detail-section{margin-bottom:20px;padding-bottom:16px}.apps-grid{grid-template-columns:1fr}.user-header-badges{flex-direction:column;align-items:flex-start;gap:4px}.user-role,.user-status{width:fit-content}.role-field{padding:8px}}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.stats-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000014;display:flex;align-items:center;gap:20px;transition:all .3s ease;border-left:4px solid transparent}.stats-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f}.stats-card-blue{border-left-color:#4299e1}.stats-card-green{border-left-color:#48bb78}.stats-card-purple{border-left-color:#9f7aea}.stats-card-yellow{border-left-color:#ecc94b}.stats-card-indigo{border-left-color:#667eea}.stats-card-blue:hover{background:linear-gradient(to right,#4299e10d,#fff)}.stats-card-green:hover{background:linear-gradient(to right,#48bb780d,#fff)}.stats-card-purple:hover{background:linear-gradient(to right,#9f7aea0d,#fff)}.stats-card-yellow:hover{background:linear-gradient(to right,#ecc94b0d,#fff)}.stats-card-indigo:hover{background:linear-gradient(to right,#667eea0d,#fff)}.stats-card-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.stats-card-blue .stats-card-icon{background:#4299e11a;color:#4299e1}.stats-card-green .stats-card-icon{background:#48bb781a;color:#48bb78}.stats-card-purple .stats-card-icon{background:#9f7aea1a;color:#9f7aea}.stats-card-yellow .stats-card-icon{background:#ecc94b1a;color:#ecc94b}.stats-card-indigo .stats-card-icon{background:#667eea1a;color:#667eea}.stats-card-content{flex:1;min-width:0}.stats-card-value{font-size:2rem;font-weight:700;color:#2d3748;margin:0 0 4px;line-height:1}.stats-card-title{font-size:.875rem;color:#718096;margin:0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-loading,.stats-error{text-align:center;padding:40px 20px;border-radius:12px}.stats-loading{display:flex;justify-content:center;align-items:center;height:200px}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #4299e1;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.stats-error{background:#fff5f5;border:1px solid #fed7d7}.error-message{color:#e53e3e;margin:0 0 16px}.retry-btn{padding:8px 16px;background:#4299e1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .3s ease}.retry-btn:hover{background:#3182ce;transform:translateY(-1px)}.stats-cards-container{margin-bottom:32px}@media(max-width:1200px){.stats-cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stats-card{padding:20px}.stats-card-icon{width:50px;height:50px;font-size:1.75rem}.stats-card-value{font-size:1.75rem}}@media(max-width:768px){.stats-cards{grid-template-columns:repeat(2,1fr);gap:12px}.stats-card{padding:16px;flex-direction:column;text-align:center;gap:12px}.stats-card-icon{width:50px;height:50px;font-size:1.5rem}.stats-card-value{font-size:1.5rem}.stats-card-title{font-size:.8125rem}}@media(max-width:480px){.stats-cards{grid-template-columns:1fr}.stats-card{flex-direction:row;text-align:left;padding:20px}.stats-card-icon{width:50px;height:50px}}.admin-dashboard{background-color:var(--color-gray-50);min-height:100vh;padding:var(--space-5) 0}.admin-container{max-width:1400px;margin:0 auto;padding:0 var(--space-5)}.admin-header{text-align:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-gray-200)}.admin-title{color:var(--color-gray-900);font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-2)}.admin-subtitle{color:var(--color-gray-600);font-size:var(--text-base)}.admin-nav{display:flex;gap:var(--space-2);margin-bottom:var(--space-5);padding:var(--space-2);background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);overflow-x:auto}.admin-nav-button{padding:var(--space-3) var(--space-4);border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--color-gray-600);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.admin-nav-button:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.admin-nav-button.active{background-color:var(--color-primary);color:var(--color-white)}.admin-content{background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);padding:var(--space-5);margin-bottom:var(--space-5);min-height:500px}.admin-error-message{background-color:#ef44441a;border:1px solid var(--color-error);color:var(--color-error);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:flex;justify-content:space-between;align-items:center}.admin-error-message button{background:none;border:none;color:var(--color-error);font-size:var(--text-lg);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.admin-error-message button:hover{opacity:.7}.admin-loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-gray-500);font-size:var(--text-base)}.admin-quick-actions{margin-top:var(--space-6)}.admin-quick-actions h3{color:var(--color-gray-900);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-4)}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.quick-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-4);background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition);min-height:120px}.quick-action:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--shadow-md)}.quick-action span:first-child{font-size:var(--text-2xl);margin-bottom:var(--space-2)}.quick-action span:last-child{color:var(--color-gray-700);font-size:var(--text-sm);font-weight:500;text-align:center}.admin-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4);background-color:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);color:var(--color-gray-600);font-size:var(--text-sm)}.admin-footer strong{color:var(--color-gray-900)}.admin-error{text-align:center;padding:var(--space-8) var(--space-4)}.admin-error h2{color:var(--color-error);font-size:var(--text-xl);margin-bottom:var(--space-3)}.admin-error p{color:var(--color-gray-600);margin-bottom:var(--space-2)}@media(max-width:768px){.admin-dashboard{padding:var(--space-4) 0}.admin-container{padding:0 var(--space-4)}.admin-content{padding:var(--space-4)}.admin-nav{gap:var(--space-1);padding:var(--space-2)}.admin-nav-button{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.admin-footer{flex-direction:column;gap:var(--space-2);text-align:center}.quick-actions-grid{grid-template-columns:1fr}}:root{--color-primary: #3b82f6;--color-primary-light: #60a5fa;--color-primary-dark: #2563eb;--color-white: #ffffff;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--hero-bg: var(--color-gray-50);--hero-title-color: var(--color-gray-900);--hero-subtitle-color: var(--color-gray-700);--hero-description-color: var(--color-gray-600);--baskin-color: var(--color-primary-dark);--space-1: .25rem;--space-2: .5rem;--space-3: 1rem;--space-4: 1.5rem;--space-5: 2rem;--space-6: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--text-7xl: 4.5rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--line-height-none: 1;--line-height-tight: 1.1;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.6;--line-height-loose: 2;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--transition: .15s ease}.dark{--color-primary: #60a5fa;--color-primary-light: #93c5fd;--color-primary-dark: #3b82f6;--color-white: #111827;--color-gray-50: #1f2937;--color-gray-100: #374151;--color-gray-200: #4b5563;--color-gray-300: #6b7280;--color-gray-400: #9ca3af;--color-gray-500: #d1d5db;--color-gray-600: #e5e7eb;--color-gray-700: #f3f4f6;--color-gray-800: #f9fafb;--color-gray-900: #ffffff;--color-success: #34d399;--color-warning: #fbbf24;--color-error: #f87171;--hero-bg: var(--color-gray-50);--hero-title-color: var(--color-gray-900);--hero-subtitle-color: var(--color-gray-700);--hero-description-color: var(--color-gray-600);--baskin-color: var(--color-primary-light);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.auth-container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:480px}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:2rem;font-weight:700;color:#2d3748;margin:0 0 8px}.auth-subtitle{font-size:1rem;color:#718096;margin:0}.auth-form{margin-bottom:32px}.auth-error{background:#fed7d7;color:#822727;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.875rem;border:1px solid #fc8181}.auth-success{background:#c6f6d5;color:#22543d;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:.875rem;border:1px solid #9ae6b4}.auth-checkbox{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-size:.875rem;color:#4a5568}.auth-checkbox input[type=checkbox]{width:18px;height:18px;border-radius:4px;border:2px solid #cbd5e0;cursor:pointer}.auth-link{color:#4299e1;text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.auth-footer{text-align:center;padding-top:24px;border-top:1px solid #e2e8f0}.auth-footer-text{color:#718096;font-size:.875rem;margin-bottom:16px}.auth-back-link{display:inline-block;color:#a0aec0;text-decoration:none;font-size:.875rem;transition:color .2s ease}.auth-back-link:hover{color:#718096}.auth-radio-group{margin-bottom:24px}.auth-radio-label{display:block;margin-bottom:8px;font-size:.875rem;font-weight:500;color:#4a5568}.auth-radio-options{display:flex;gap:20px}.auth-radio-option{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.875rem;color:#4a5568}.auth-radio-option input[type=radio]{width:18px;height:18px;border:2px solid #cbd5e0;border-radius:50%;cursor:pointer}.auth-radio-option input[type=radio]:checked{border-color:#4299e1;background-color:#4299e1;background-clip:content-box;padding:3px}.verification-icon{font-size:3rem;margin-bottom:20px}.verification-inputs{text-align:center;margin-bottom:32px}.verification-label{font-size:.875rem;color:#718096;margin-bottom:20px}.code-inputs{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.code-input{width:60px;height:60px;border:2px solid #e2e8f0;border-radius:12px;font-size:1.5rem;font-weight:600;text-align:center;color:#2d3748;transition:all .3s ease;background:#f7fafc}.code-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e126;background:#fff}.code-input.filled{border-color:#4299e1;background:#fff;box-shadow:0 2px 10px #4299e133}.verification-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.verification-help{text-align:center;font-size:.875rem;color:#718096;margin-top:20px}.verification-help p{margin:8px 0}.verification-help .auth-link{background:none;border:none;padding:0;font-size:inherit;cursor:pointer}@media(max-width:640px){.auth-container{padding:24px;max-width:100%}.auth-title{font-size:1.5rem}.code-inputs{gap:12px}.code-input{width:50px;height:50px;font-size:1.25rem}.auth-radio-options{flex-direction:column;gap:12px}}@media(max-width:480px){.code-inputs{gap:8px}.code-input{width:45px;height:45px}.auth-page{padding:16px}}.welcome-modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease}.welcome-modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease}.welcome-modal-content{padding:40px;text-align:center}.welcome-icon{font-size:4rem;margin-bottom:20px;animation:bounce .6s ease}.welcome-title{font-size:2rem;font-weight:700;color:#2d3748;margin:0 0 12px}.welcome-subtitle{font-size:1.1rem;color:#4a5568;margin:0 0 16px}.welcome-message{font-size:1rem;color:#718096;line-height:1.6;margin:0 0 24px}.welcome-user-info{background:#f7fafc;border-radius:12px;padding:20px;margin-bottom:30px;border:1px solid #e2e8f0}.user-info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #edf2f7}.user-info-item:last-child{border-bottom:none}.info-label{font-size:.9rem;color:#718096;font-weight:500}.info-value{font-size:1rem;color:#2d3748;font-weight:600}.welcome-actions{margin-top:30px}.welcome-note{font-size:.9rem;color:#718096;margin:20px 0;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #4299e1}.login-details{background:#f7fafc;border-radius:10px;padding:15px;margin:20px 0;text-align:left}.detail-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.detail-item:last-child{margin-bottom:0}.detail-label{font-size:.85rem;color:#718096;font-weight:500}.detail-value{font-family:Courier New,monospace;background:#edf2f7;padding:6px 12px;border-radius:6px;font-size:.9rem;color:#2d3748}.welcome-secondary-actions{display:flex;justify-content:space-between;align-items:center;margin-top:25px;padding-top:20px;border-top:1px solid #e2e8f0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:640px){.welcome-modal-content{padding:24px}.welcome-icon{font-size:3rem}.welcome-title{font-size:1.5rem}.user-info-item{flex-direction:column;align-items:flex-start;gap:5px}.welcome-secondary-actions{flex-direction:column;gap:12px;align-items:stretch}.detail-item{flex-direction:column;align-items:flex-start;gap:5px}.detail-value{width:100%;text-align:center}}@media(max-width:480px){.welcome-modal-overlay{padding:10px}.welcome-modal{border-radius:12px}.welcome-modal-content{padding:20px}}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:60vh;background:transparent}.loading-content{text-align:center;max-width:300px;padding:40px;border-radius:12px;background:#fffffff2;box-shadow:0 4px 20px #0000001a}.loader{border:4px solid #f3f3f3;border-top:4px solid #4299e1;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#4a5568;font-size:1rem;font-weight:500;margin:0}@media(max-width:768px){.loading-content{padding:30px}.loader{width:40px;height:40px}.loading-text{font-size:.875rem}}.forgot-password-info{background:#f0f9ff;border-radius:10px;padding:16px;margin-bottom:20px;border-left:4px solid #3b82f6}.forgot-password-info p{margin:0;color:#0369a1;font-size:.95rem;line-height:1.5}.auth-success{background:#d1fae5;border:1px solid #10b981;color:#065f46;padding:20px;border-radius:12px;margin-bottom:24px;text-align:left}.auth-success p{margin:0 0 15px;font-weight:500}.auth-success p:first-child{font-size:1rem;font-weight:600}.email-sent-to{background:#ecfdf5;border-radius:8px;padding:12px;margin:15px 0;border:1px solid #a7f3d0}.email-label{font-size:.85rem;color:#047857;margin:0 0 5px;font-weight:500}.email-value{font-size:1rem;color:#065f46;font-weight:600;margin:0;word-break:break-all}.success-instructions{margin-top:20px;padding-top:15px;border-top:1px dashed #34d399}.success-instructions p{margin:10px 0;color:#065f46}.success-instructions ul{margin:10px 0;padding-left:20px;color:#065f46}.success-instructions li{margin-bottom:8px;font-size:.9rem}.check-spam{font-style:italic;color:#059669;font-size:.9rem;margin-top:15px!important}.resend-section{text-align:center;margin-top:25px;padding-top:20px;border-top:1px solid #e2e8f0}.resend-note{font-size:.85rem;color:#718096;margin-top:10px}.forgot-password-help{margin-top:20px;padding-top:15px;border-top:1px solid #e2e8f0;text-align:center}.forgot-password-help p{font-size:.85rem;color:#718096;margin:0}.auth-footer-links button.auth-back-link{background:none;border:none;color:#a0aec0;font-size:.875rem;cursor:pointer;padding:0;text-decoration:none;transition:color .2s ease}.auth-footer-links button.auth-back-link:hover{color:#718096;text-decoration:underline}.auth-footer-links button.auth-back-link:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.auth-success{padding:16px}.success-instructions ul{padding-left:16px}.auth-footer-links{flex-direction:column;gap:15px;align-items:center}.auth-footer-links a,.auth-footer-links button{width:100%;text-align:center}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;color:#1a1a1a;background-color:#f8fafc;min-height:100vh}#root{min-height:100vh}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}
