:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.lipstick-display-fullscreen{position:relative;width:100vw;height:100vh;background:#000;overflow:hidden;display:flex;align-items:center;justify-content:center}.display-canvas-fullscreen{width:100vw;height:100vh;object-fit:cover;transform:scaleX(-1)!important;-webkit-transform:scaleX(-1)!important;-moz-transform:scaleX(-1)!important;-ms-transform:scaleX(-1)!important;position:absolute;top:0;left:0}.status-bar{position:absolute;top:20px;left:20px;right:20px;display:flex;align-items:center;gap:20px;background:#000000b3;padding:15px 20px;border-radius:10px;color:#fff;font-size:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.connection-indicator{display:flex;align-items:center;gap:8px;font-weight:600}.connection-indicator.connected{color:#4caf50}.connection-indicator.disconnected{color:#f44336}.face-indicator{color:#4caf50;font-weight:600;display:flex;align-items:center;gap:8px}.active-shade-indicator{flex:1;text-align:center;font-size:1.3rem;font-weight:700;color:#e91e63;text-shadow:0 2px 4px rgba(0,0,0,.5)}.fps-indicator{font-family:Courier New,monospace;color:#0f0;font-weight:700}.init-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:100}.loading-message,.error-message{text-align:center;color:#fff;padding:40px;max-width:600px}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-message h2,.error-message h2{font-size:2rem;margin:0 0 15px;font-weight:700}.loading-message p,.error-message p{font-size:1.2rem;opacity:.9;margin-bottom:20px}.loading-steps{margin-top:30px;text-align:left;background:#ffffff1a;padding:20px;border-radius:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.loading-steps .step{padding:8px 0;font-size:1rem;opacity:.8}.error-icon{font-size:4rem;margin-bottom:20px}.error-actions{display:flex;gap:15px;justify-content:center;margin:30px 0}.reload-button,.fallback-button{padding:15px 30px;font-size:1.1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}.reload-button{background:#4caf50;color:#fff}.reload-button:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.fallback-button{background:#fff3;color:#fff;border:2px solid white}.fallback-button:hover{background:#ffffff4d;transform:translateY(-2px)}.error-help{margin-top:30px;text-align:left;background:#0000004d;padding:20px;border-radius:10px;font-size:.95rem}.error-help strong{display:block;margin-bottom:10px;font-size:1.1rem}.error-help ul{list-style:none;padding:0;margin:0}.error-help li{padding:5px 0 5px 25px;position:relative}.error-help li:before{content:"→";position:absolute;left:0;font-weight:700}.debug-panel{position:absolute;bottom:20px;right:20px;background:#000000d9;padding:15px;border-radius:10px;color:#fff;font-size:.9rem;min-width:250px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20}.debug-panel button{padding:6px 12px;margin:4px;border:none;border-radius:5px;background:#ffffff26;color:#fff;cursor:pointer;font-size:.85rem;transition:all .2s}.debug-panel button:hover{background:#ffffff40}.slider-group{margin-top:12px;padding-top:8px;border-top:1px solid rgba(255,255,255,.2)}.slider-group label{display:block;margin-bottom:6px;font-size:.85rem;color:#ccc}.slider-group input[type=range]{width:100%;height:4px;border-radius:2px;background:#fff3;outline:none;-webkit-appearance:none}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#4caf50;cursor:pointer}.slider-group input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#4caf50;cursor:pointer;border:none}.debug-info{display:inline-block;padding:4px 8px;background:#00000080;border-radius:4px;font-size:.85rem;font-family:Courier New,monospace;color:#0f0}@media (max-width: 768px){.status-bar{flex-direction:column;align-items:flex-start;gap:10px;font-size:.9rem}.active-shade-indicator{font-size:1.1rem}.loading-message h2,.error-message h2{font-size:1.5rem}.loading-message p,.error-message p{font-size:1rem}.error-actions{flex-direction:column}.reload-button,.fallback-button{width:100%}.debug-panel{bottom:10px;right:10px;min-width:200px;font-size:.8rem}}.look-selector{width:100%;height:100%;overflow:hidden;padding:0}.selector-title{display:none}.looks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:8px;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.look-card{background:#fff;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000026;border:3px solid transparent;position:relative}.look-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 8px 16px #0003}.look-card.selected{border-color:gold;box-shadow:0 8px 16px #ffd70066;transform:scale(1.02)}.look-thumbnail{width:100%;aspect-ratio:1;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff;font-weight:700}.look-number{text-shadow:2px 2px 4px rgba(0,0,0,.3)}.look-info{padding:10px}.look-name{font-size:.95rem;font-weight:700;color:#333;margin-bottom:4px}.look-description{font-size:.75rem;color:#666;margin-bottom:6px}.selected-badge{display:inline-block;background:#4caf50;color:#fff;padding:3px 8px;border-radius:8px;font-size:.7rem;font-weight:700}.look-products-preview{position:absolute;top:100%;left:0;right:0;background:#fff;border-radius:0 0 16px 16px;padding:15px;box-shadow:0 4px 12px #00000026;z-index:10;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.product-preview-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.85rem;color:#666}.product-color-dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.1);flex-shrink:0}.product-preview-name{flex:1}@media (orientation: landscape){.looks-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;padding:6px}.look-card{border-radius:10px;border-width:2px}.thumbnail-placeholder{font-size:2rem}.look-info{padding:8px}.look-name{font-size:.85rem;margin-bottom:3px}.look-description{font-size:.7rem;margin-bottom:5px}.selected-badge{padding:2px 6px;font-size:.65rem}}@media (max-width: 768px){.looks-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.look-name{font-size:.9rem}.look-description{font-size:.75rem}}.product-list{background:#fffffff2;border-radius:12px;padding:12px;box-shadow:0 4px 16px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.3);flex-shrink:0;margin-bottom:10px}.product-list.empty{text-align:center;padding:12px}.empty-message{font-size:.9rem;color:#666;margin-bottom:5px;font-weight:500}.empty-hint{font-size:.75rem;color:#999}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.list-header h3{font-size:.9rem;color:#333;font-weight:700;margin:0}.clear-all-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:6px 12px;border-radius:10px;font-size:.75rem;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #f443364d}.clear-all-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f4433666}.products-container{display:flex;flex-direction:column;gap:6px;max-height:100px;overflow-y:auto;-webkit-overflow-scrolling:touch}.product-item{display:flex;align-items:center;gap:8px;padding:6px;background:#f5f5f5;border-radius:8px;transition:all .2s ease}.product-item:hover{background:#eee;transform:translate(4px)}.product-icon{flex-shrink:0}.product-color-swatch{width:28px;height:28px;border-radius:6px;box-shadow:0 2px 4px #00000026;border:2px solid white}.product-details{flex:1;min-width:0}.product-name{font-size:.8rem;font-weight:600;color:#333;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-type{font-size:.7rem;color:#666;text-transform:capitalize}.remove-btn{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:#fff;color:#f44336;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer;border:2px solid #f44336}.remove-btn:hover{background:#f44336;color:#fff;transform:rotate(90deg)}@media (orientation: landscape){.product-list{padding:10px;margin-bottom:8px}.products-container{max-height:80px}.product-item{padding:5px;gap:6px}.product-color-swatch{width:24px;height:24px}}@media (max-width: 768px){.list-header h3{font-size:.85rem}.product-name{font-size:.75rem}.product-type{font-size:.7rem}}.lipstick-shade-selector{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.selector-title{margin:0 0 15px;font-size:1.3rem;font-weight:700;color:#e91e63;text-align:center;border-bottom:2px solid #e91e63;padding-bottom:10px;display:none}.shades-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.shade-button{position:relative;background:#fff;border:3px solid #e0e0e0;border-radius:12px;padding:8px;cursor:pointer;transition:all .2s ease;text-align:center;overflow:hidden}.shade-button:hover{transform:translateY(-3px);box-shadow:0 6px 16px #00000026;border-color:#bbb}.shade-button.selected{border-color:#e91e63;border-width:4px;box-shadow:0 6px 20px #e91e6366;transform:scale(1.05)}.shade-preview{position:relative;width:100%;padding-top:120%;border-radius:8px;overflow:hidden;background:#f5f5f5;margin-bottom:8px}.shade-preview img,.shade-color-fallback{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.shade-color-fallback{display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff}.shade-details{text-align:center}.shade-name{font-size:.9rem;font-weight:600;color:#333;line-height:1.2;text-align:center}.shade-finish{font-size:.85rem;color:#666;font-style:italic}.selected-check{position:absolute;top:15px;right:15px;width:32px;height:32px;background:#e91e63;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:0 2px 8px #0003}.lipstick-selector-loading{padding:30px;text-align:center;color:#666;font-size:1rem}@media (orientation: landscape){.shades-grid{grid-template-columns:repeat(6,1fr);gap:12px}.selector-title{font-size:1.1rem;margin-bottom:12px}.shade-name{font-size:.9rem}.shade-finish{font-size:.75rem}}@media (max-width: 767px) and (orientation: portrait){.shades-grid{grid-template-columns:repeat(2,1fr);gap:12px}.selector-title{font-size:1.1rem}}.controller-view{width:100%;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:12px;overflow:hidden;display:flex;flex-direction:column}.controller-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;color:#fff;background:#ffffff1a;padding:12px 15px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.controller-header h1{font-size:1.3rem;font-weight:700;letter-spacing:.5px}.connection-status{display:flex;align-items:center;gap:6px;background:#fff3;padding:6px 12px;border-radius:12px;font-weight:700;font-size:.85rem}.status-dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-dot.connected{background:#4caf50}.status-dot.disconnected{background:#f44336}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.devices-status{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:4px 8px;background:transparent;opacity:.4;flex-shrink:0}.device-card{display:flex;align-items:center;gap:3px;background:#ffffff26;border-radius:6px;padding:3px 6px;font-size:.65rem}.device-card.active{background:#4caf5040}.device-card.inactive{background:#ffffff1a;opacity:.6}.device-icon{font-size:.75rem}.device-name{display:none}.device-state{color:#fff;font-size:.65rem;font-weight:500}.selected-item-card{background:#fffffff2;border-radius:16px;padding:20px;margin-bottom:20px;box-shadow:0 4px 6px #0000001a}.selected-item-card h3{margin-bottom:15px;color:#333}.selected-item-info{display:flex;align-items:center;gap:15px;margin-bottom:15px}.color-preview{width:60px;height:60px;border-radius:12px;box-shadow:0 2px 4px #0003}.item-name{font-size:1.3rem;font-weight:700;color:#333}.item-category{font-size:.9rem;color:#666;text-transform:uppercase}.no-selection{color:#666;font-style:italic;text-align:center;padding:20px}.clear-button{background:#f44336;color:#fff;width:100%;padding:12px;border-radius:8px;font-weight:700}.clear-button:hover{background:#d32f2f}.main-content{flex:1;overflow:hidden;margin-bottom:8px;display:flex;flex-direction:column;min-height:0}.view-mode-tabs{display:flex;gap:8px;margin:10px 0;background:#ffffff26;padding:5px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.mode-tab{flex:1;background:transparent;color:#fff;padding:10px 16px;border-radius:8px;font-weight:600;font-size:.9rem;transition:all .3s ease;border:2px solid transparent}.mode-tab:hover{background:#ffffff1a}.mode-tab.active{background:#fff;color:#667eea;box-shadow:0 4px 12px #00000026}.products-view{background:#fffffff2;border-radius:12px;padding:12px;box-shadow:0 4px 12px #0000001a;height:100%;overflow:hidden;display:flex;flex-direction:column}.category-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px;margin-bottom:12px;flex-shrink:0}.category-tab{background:#f5f5f5;color:#333;padding:8px;border-radius:10px;font-weight:700;font-size:.8rem;text-transform:capitalize;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .2s ease}.category-tab:hover{background:#e0e0e0;transform:translateY(-2px)}.category-tab.active{background:#f5576c;color:#fff}.category-icon{font-size:1.2rem}.category-name{font-size:.75rem}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;overflow-y:auto;-webkit-overflow-scrolling:touch}.product-card{background:#fff;border-radius:10px;padding:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #0000001a;border:2px solid transparent}.product-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026;border-color:#f5576c}.product-color{width:100%;height:55px;border-radius:8px;margin-bottom:8px;box-shadow:0 2px 4px #0000001a}.product-card .product-name{font-size:.8rem;text-align:center;color:#333;font-weight:500}@media (orientation: landscape){.controller-view{padding:10px}.controller-header{padding:10px 12px;margin-bottom:8px}.controller-header h1{font-size:1.2rem}.view-mode-tabs{margin:8px 0}.category-tabs{grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:6px;margin-bottom:10px}.products-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.product-color{height:50px}.devices-status{margin-top:6px;padding:3px 6px}}@media (max-width: 768px){.controller-header h1{font-size:1.2rem}.category-tabs{grid-template-columns:repeat(3,1fr)}}.manicure-view{width:100%;min-height:100vh;background:linear-gradient(135deg,#4facfe,#00f2fe);padding:20px 20px 40px}.manicure-header{display:flex;justify-content:space-between;align-items:center;color:#fff;margin-bottom:20px}.manicure-header h1{font-size:1.8rem}.connection-indicator{font-size:1.5rem}.camera-section{background:#fff;border-radius:20px;padding:20px;margin-bottom:20px;box-shadow:0 4px 12px #0000001a;min-height:400px;display:flex;align-items:center;justify-content:center}.camera-placeholder{text-align:center;padding:40px 20px}.placeholder-icon{font-size:5rem;margin-bottom:20px}.camera-placeholder h2{font-size:1.8rem;color:#333;margin-bottom:10px}.camera-placeholder p{color:#666;margin-bottom:30px;font-size:1.1rem}.start-camera-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;padding:16px 40px;font-size:1.2rem;font-weight:700;border-radius:30px;box-shadow:0 4px 12px #4facfe66}.start-camera-btn:hover{transform:translateY(-3px);box-shadow:0 6px 16px #4facfe80}.camera-container{width:100%;position:relative}.manicure-canvas{width:100%;border-radius:12px;display:block}.stop-camera-btn{position:absolute;top:10px;right:10px;background:#f44336e6;color:#fff;padding:10px 20px;border-radius:20px;font-weight:700;font-size:.9rem}.selected-color-display{background:#fff;border-radius:16px;padding:20px;margin-bottom:20px;display:flex;align-items:center;gap:20px;box-shadow:0 4px 12px #0000001a}.color-swatch{width:80px;height:80px;border-radius:12px;box-shadow:0 4px 8px #0003;flex-shrink:0}.color-info{flex-grow:1}.color-name{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:5px}.color-hex{font-size:1.1rem;color:#666;font-family:monospace}.colors-section{background:#fff;border-radius:16px;padding:20px;margin-bottom:20px;box-shadow:0 4px 12px #0000001a}.colors-section h3{color:#333;margin-bottom:15px;font-size:1.3rem}.colors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:12px}.color-option{aspect-ratio:1;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px #00000026;border:3px solid transparent;display:flex;align-items:center;justify-content:center}.color-option:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000040}.color-option.selected{border-color:#fff;box-shadow:0 4px 12px #0000004d;transform:scale(1.05)}.check-mark{font-size:2rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);font-weight:700}.info-section{background:#ffffffe6;border-radius:16px;padding:20px;color:#333;box-shadow:0 4px 12px #0000001a}.info-section p{margin-bottom:10px;font-size:1rem;line-height:1.6}.info-section .note{font-size:.9rem;color:#666;font-style:italic}@media (max-width: 768px){.manicure-header h1{font-size:1.4rem}.camera-section{min-height:300px;padding:15px}.colors-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:10px}}.home-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.home-content{text-align:center;max-width:1200px;padding:40px}.home-content h1{font-size:3rem;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.home-content>p{font-size:1.5rem;margin-bottom:3rem;opacity:.9}.link-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:2rem}.home-link{background:#fff;color:#333;padding:2rem;border-radius:16px;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 6px #0000001a}.home-link:hover{transform:translateY(-8px);box-shadow:0 12px 24px #0003}.home-link .icon{font-size:4rem;margin-bottom:1rem}.home-link h2{font-size:1.5rem;margin-bottom:.5rem;color:#667eea}.home-link p{color:#666;font-size:1rem}.home-link.display h2{color:#667eea}.home-link.controller h2{color:#f093fb}.home-link.manicure h2{color:#4facfe}@media (max-width: 768px){.home-content h1{font-size:2rem}.home-content>p{font-size:1.2rem}.link-grid{grid-template-columns:1fr;gap:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100vw;height:100vh;overflow:hidden}.view-container{width:100%;height:100%;display:flex;flex-direction:column}button{cursor:pointer;border:none;padding:12px 24px;font-size:16px;border-radius:8px;transition:all .3s ease}button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}button:active{transform:translateY(0)}
