@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";body{margin:0;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root{--primary: #2196F3;--primary-dark: #1976D2;--primary-light: #42A5F5;--success: #4CAF50;--warning: #FF9800;--error: #F44336;--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-card: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--border: #3a3a3a;--experimental: #FFB74D}.experimental-feature{border:2px solid var(--experimental)!important;position:relative;transition:all .3s ease}.experimental-feature:hover{border-color:var(--warning);box-shadow:0 0 12px #ffb74d4d}.experimental-feature:after{content:"BETA";position:absolute;top:-10px;right:10px;background:var(--experimental);color:#1a1a1a;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.5px}*{margin:0;padding:0;box-sizing:border-box}.hidden{display:none!important}body{background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden;line-height:1.6;-webkit-overflow-scrolling:touch}#root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}@media(max-width:768px){#root{padding:2rem 1rem 1rem;align-items:flex-start}}.app{width:100%}.app.iframe-mode{max-width:100%;padding:0}.app.iframe-mode .card{border-radius:0;border:none;border-bottom:1px solid var(--border);margin-bottom:0}.app.iframe-mode .guidance-card{border-radius:8px;border:1px solid var(--border);margin:1rem}.header{text-align:center;margin-bottom:2rem}.header-logo{display:flex;justify-content:center;margin-bottom:1rem}.app-logo{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(33,150,243,.3));animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.header p{font-size:.95rem;color:var(--text-secondary);font-weight:400}@media(max-width:768px){.header{margin-bottom:1.5rem}.app-logo{width:64px;height:64px}.header h1{font-size:1.5rem}.header p{font-size:.875rem}}.card{background:var(--bg-card);border-radius:12px;padding:1.5rem;margin-bottom:1rem;border:1px solid var(--border)}@media(max-width:768px){.card{padding:1rem;border-radius:8px}}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500;margin-left:auto}.status-badge.connected{background:#4caf5026;color:var(--success)}.status-badge.disconnected{background:#b0b0b026;color:var(--text-secondary)}.btn-help{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #2196f34d}.btn-help:hover{background:var(--primary-light);transform:scale(1.1);box-shadow:0 3px 12px #2196f380}.btn-help:active{transform:scale(.95)}.button-group{display:grid;gap:.75rem;margin-bottom:1.5rem}@media(min-width:640px){.button-group{grid-template-columns:repeat(4,1fr)}}@media(max-width:639px){.button-group{grid-template-columns:1fr}}.btn{padding:.875rem 1.25rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn:hover:not(:disabled){background:var(--bg-card);border-color:var(--primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.btn-primary:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}.btn.btn-success{background:var(--success);border-color:var(--success);color:#fff}.btn.btn-success:hover:not(:disabled){background:#45a049;border-color:#45a049}.btn-icon{font-size:1.1rem}.terminal{background:#1a1a1a;border:1px solid var(--border);border-radius:8px;overflow:hidden}.terminal-header{background:var(--bg-secondary);padding:.75rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--border)}.terminal-dot{width:12px;height:12px;border-radius:50%;background:var(--text-secondary);opacity:.3}.terminal-title{margin-left:auto;font-family:Inter,monospace;font-size:.75rem;color:var(--text-secondary);font-weight:600;letter-spacing:.5px}.terminal-body{padding:1rem;min-height:120px;max-height:300px;overflow-y:auto;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.85rem;line-height:1.6;-webkit-overflow-scrolling:touch}@media(max-width:768px){.terminal-body{padding:.75rem;font-size:.8rem;max-height:200px}}.terminal-body pre{color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word}.terminal-body::-webkit-scrollbar{width:8px}.terminal-body::-webkit-scrollbar-track{background:transparent}.terminal-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.terminal-body::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.info-section{margin-top:1rem;padding:1rem;background:#2196f314;border-left:3px solid var(--primary);border-radius:4px}.info-section p{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.6}.info-section strong{color:var(--primary);font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.btn:disabled .btn-icon{animation:spin 1s linear infinite}@media(min-width:640px){.button-group{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.button-group{gap:.5rem}.btn{padding:.75rem 1rem;font-size:.875rem}}.apps-list{margin-top:1.5rem;border-radius:8px;overflow:hidden;max-height:0;opacity:0;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease,margin .3s ease;margin-bottom:0}.apps-list.expanded{max-height:500px;opacity:1;border:1px solid var(--border);margin-bottom:0}.apps-list.collapsed{max-height:0;opacity:0;margin-top:0;margin-bottom:0;border:none}.apps-header{background:var(--bg-secondary);padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);font-weight:600;font-size:.9rem}.btn-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.btn-close:hover{background:var(--border);color:var(--text-primary)}.btn-minimize{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;font-weight:300;line-height:1}.btn-minimize:hover{background:var(--border);color:var(--text-primary)}.apps-container{max-height:300px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(max-width:768px){.apps-container{max-height:250px}}.apps-container::-webkit-scrollbar{width:8px}.apps-container::-webkit-scrollbar-track{background:var(--bg-card)}.apps-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.apps-container::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.app-item{padding:.875rem 1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);transition:background .2s ease;gap:.75rem}@media(max-width:768px){.app-item{padding:.75rem .875rem;flex-wrap:nowrap}}.app-item:last-child{border-bottom:none}.app-item:hover{background:var(--bg-secondary)}.app-info{flex:1;margin-right:1rem;display:flex;flex-direction:column;gap:.25rem;min-width:0}@media(max-width:768px){.app-info{margin-right:.5rem}}.app-label{font-size:.95rem;color:var(--text-primary);font-weight:500}.app-package{font-size:.8rem;color:var(--text-secondary);font-family:SF Mono,Monaco,Courier New,monospace;word-break:break-all;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.app-label{font-size:.875rem}.app-package{font-size:.75rem}}.app-name{font-size:.875rem;color:var(--text-primary);font-family:SF Mono,Monaco,Courier New,monospace;word-break:break-all;flex:1;margin-right:1rem}.btn-uninstall{padding:.4rem .875rem;font-size:.8rem;background:transparent;color:var(--error);border:1px solid var(--error);border-radius:4px;cursor:pointer;transition:all .2s ease;font-weight:500;white-space:nowrap;flex-shrink:0}@media(max-width:768px){.btn-uninstall{padding:.35rem .75rem;font-size:.75rem}}.btn-uninstall:hover:not(:disabled){background:var(--error);color:#fff}.btn-uninstall:disabled{opacity:.5;cursor:not-allowed}.btn-file{position:relative;overflow:hidden}.btn-file.disabled{opacity:.5;cursor:not-allowed!important;pointer-events:none}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(max-width:768px){.modal-overlay{padding:2rem .5rem .5rem;align-items:flex-start}}.modal{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;animation:modalFadeIn .2s ease}@media(max-width:768px){.modal{max-height:90vh;border-radius:8px}}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.modal-body{padding:1.5rem;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}@media(max-width:768px){.modal-body{padding:1rem}}.modal-body p{margin-bottom:1rem;color:var(--text-primary);line-height:1.6}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end}.btn-toggle-permissions{background:var(--bg-secondary);color:var(--primary);border:1px solid var(--primary);padding:.65rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;width:100%;margin-bottom:1rem}.btn-toggle-permissions:hover{background:var(--primary);color:#fff}.permissions-list{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:.75rem;max-height:300px;overflow-y:auto;animation:slideDown .3s ease;-webkit-overflow-scrolling:touch}@media(max-width:768px){.permissions-list{max-height:200px;padding:.5rem}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}.permissions-list::-webkit-scrollbar{width:8px}.permissions-list::-webkit-scrollbar-track{background:transparent}.permissions-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.permission-item{padding:.5rem .75rem;font-size:.85rem;color:var(--text-secondary);font-family:SF Mono,Monaco,Courier New,monospace;border-bottom:1px solid var(--border)}.permission-item:last-child{border-bottom:none}.guidance-card{margin-top:2rem;background:linear-gradient(135deg,#2196f30d,#2196f305);border:1px solid rgba(33,150,243,.2)}.guidance-content{margin-top:1rem}.guidance-step{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:8px;border-left:3px solid var(--primary);transition:all .3s ease}.guidance-step:hover{background:var(--bg-card);transform:translate(5px);border-left-color:var(--primary-light)}.guidance-step:last-child{margin-bottom:0}.step-number{flex-shrink:0;width:36px;height:36px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem}.step-content{flex:1}.step-content h4{margin:0 0 .5rem;color:var(--text-primary);font-size:1rem;font-weight:600}.step-content p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.step-content strong{color:var(--primary-light);font-weight:600}@media(max-width:768px){.guidance-card{margin-top:1.5rem}.guidance-step{padding:.875rem;gap:.75rem}.step-number{width:32px;height:32px;font-size:1rem}.step-content h4{font-size:.95rem}.step-content p{font-size:.85rem}}@media(max-width:639px){#root{padding:1rem}.header h1{font-size:1.5rem}.card{padding:1.25rem}.modal-header{padding:1rem 1.25rem}.modal-footer{padding:.875rem 1.25rem;flex-wrap:wrap}.modal-footer .btn{flex:1;min-width:120px}.status-badge{font-size:.8rem;padding:.3rem .65rem}}.btn-guidance-toggle{width:100%;max-width:600px;margin:2rem auto;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #2196f34d;display:block}.btn-guidance-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2196f366}.btn-guidance-toggle:active{transform:translateY(0)}@media(max-width:768px){.btn-guidance-toggle{font-size:1rem;padding:.875rem 1.25rem;margin:1.5rem auto}}.step-image-container{position:relative;margin:1rem 0;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px #0000004d;cursor:pointer;transition:transform .2s ease}.step-image-container:hover{transform:scale(1.02)}.step-image{width:100%;height:auto;display:block;border-radius:8px}.custom-marker{position:relative;width:0;height:0}.custom-marker .pulse-ring{position:absolute;width:40px;height:40px;border:3px solid #2196F3;border-radius:50%;top:0;left:0;transform:translate(-50%,-50%);animation:pulse-ring 1.5s cubic-bezier(.215,.61,.355,1) infinite}.custom-marker .pulse-dot{position:absolute;width:16px;height:16px;background:#2196f3;border-radius:50%;top:0;left:0;transform:translate(-50%,-50%);box-shadow:0 0 20px #2196f3cc;animation:pulse-dot 1.5s cubic-bezier(.455,.03,.515,.955) infinite}.custom-marker-yellow{position:relative;width:0;height:0}.custom-marker-yellow .pulse-ring{position:absolute;width:40px;height:40px;border:3px solid #FFC107;border-radius:50%;top:0;left:0;transform:translate(-50%,-50%);opacity:1}.custom-marker-yellow .pulse-dot{position:absolute;width:16px;height:16px;background:#ffc107;border-radius:50%;top:0;left:0;transform:translate(-50%,-50%);box-shadow:0 0 20px #ffc107cc;opacity:1}.lightbox-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease;cursor:zoom-out}.lightbox-close{position:absolute;top:20px;right:20px;width:50px;height:50px;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10001}.lightbox-close:hover{background:#fff3;border-color:#ffffff80;transform:rotate(90deg)}.lightbox-image{max-width:90%;max-height:90vh;border-radius:8px;box-shadow:0 8px 32px #00000080;cursor:default}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.connection-info{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.info-box{background:var(--bg-secondary);border-radius:8px;padding:1rem;border-left:4px solid var(--primary)}.warning-box{border-left-color:var(--warning)}.steps-box{border-left-color:var(--primary)}.compatibility-box{border-left-color:var(--success)}.info-box strong{display:block;font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}.info-box p{margin:.5rem 0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.info-box ul,.info-box ol{margin:.5rem 0;padding-left:1.5rem;color:var(--text-secondary)}.info-box li{margin:.5rem 0;font-size:.9rem;line-height:1.6}.info-box li strong{display:inline;color:var(--primary-light);font-size:inherit;margin:0}.info-box .note{font-size:.85rem;color:var(--warning);margin-top:.75rem;font-style:italic}@media(max-width:768px){.connection-info{gap:.75rem}.info-box{padding:.75rem}.info-box strong{font-size:.9rem}.info-box p,.info-box li{font-size:.85rem}}@keyframes pulse-ring{0%{transform:translate(-50%,-50%) scale(.8);opacity:1}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.7}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}@keyframes pulse-dot{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.8}}@media(max-width:768px){.step-image-container{margin:.75rem 0}.custom-marker .pulse-ring{width:30px;height:30px;border:2px solid #2196F3}.custom-marker .pulse-dot{width:12px;height:12px}.custom-marker-yellow .pulse-ring{width:30px;height:30px;border:2px solid #FFC107}.custom-marker-yellow .pulse-dot{width:12px;height:12px}.lightbox-close{top:10px;right:10px;width:40px;height:40px;font-size:1.5rem}.lightbox-image{max-width:95%;max-height:95vh}}.help-section{max-height:0;overflow:hidden;transition:max-height .5s ease-in-out,opacity .5s ease-in-out,margin-top .5s ease-in-out;opacity:0;margin-top:0}.help-section-open{max-height:5000px;opacity:1;margin-top:2rem;animation:slideDown .5s ease-out}@keyframes slideDown{0%{max-height:0;opacity:0;transform:translateY(-20px)}to{max-height:5000px;opacity:1;transform:translateY(0)}}.help-section .card-header-help{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-card) 100%)}.help-section .card-header-help h2{margin:0;font-size:1.5rem;color:var(--primary)}.help-section .btn-close{background:none;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.help-section .btn-close:hover{background:var(--bg-secondary);color:var(--error);transform:rotate(90deg)}@media(max-width:768px){.help-section-open{margin-top:1rem}.help-section .card-header-help{padding:1rem}.help-section .card-header-help h2{font-size:1.2rem}}.splash-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a0a0a,#1a1a1a,#0a0a0a);display:flex;align-items:center;justify-content:center;z-index:9999;animation:splashFadeOut .5s ease-out 3s forwards}.splash-content{display:flex;flex-direction:column;align-items:center;gap:2rem}.splash-logo{animation:logoAppear 1s ease-out forwards;opacity:0}.splash-logo-img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 0 30px rgba(33,150,243,.8));animation:logoGlow 2s ease-in-out infinite}@keyframes logoAppear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes logoGlow{0%,to{filter:drop-shadow(0 0 20px rgba(33,150,243,.6))}50%{filter:drop-shadow(0 0 40px rgba(33,150,243,1))}}.splash-text{text-align:center;animation:textAppear .8s ease-out .8s forwards;opacity:0}.splash-title{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin:0;margin-bottom:.5rem;background:linear-gradient(135deg,#2196f3,#42a5f5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.splash-subtitle{font-size:1.1rem;color:var(--text-secondary);margin:0;font-weight:400}@keyframes textAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.splash-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;animation:loadingAppear .8s ease-out 1.6s forwards;opacity:0;margin-top:1rem}.loading-bar{width:200px;height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden;position:relative}.loading-bar:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,var(--primary) 50%,transparent 100%);animation:loadingProgress 1.5s ease-in-out infinite}@keyframes loadingProgress{0%{left:-100%}to{left:100%}}.loading-text{font-size:.9rem;color:var(--text-secondary);margin:0;letter-spacing:.5px}@keyframes loadingAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes splashFadeOut{0%{opacity:1}to{opacity:0;visibility:hidden}}.app-hidden{opacity:0;visibility:hidden}.app-visible{animation:appSlideUp .8s ease-out forwards}@keyframes appSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.splash-logo-img{width:90px;height:90px}.splash-title{font-size:2rem}.splash-subtitle{font-size:1rem}.loading-bar{width:150px}.loading-text{font-size:.85rem}}
