*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:linear-gradient(135deg,#1a1a2e,#16213e);min-height:100vh;color:#fff;overflow:hidden}
#app{width:100%;height:100vh;display:flex;flex-direction:column}
.screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.hidden{display:none!important}
.logo{text-align:center;margin-bottom:40px}
.logo-icon{font-size:64px;margin-bottom:20px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.logo h1{font-size:32px;margin-bottom:10px;background:linear-gradient(90deg,#4facfe,#00f2fe);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo p{color:#888;font-size:16px}
.connect-form{width:100%;max-width:400px}
.input-group{margin-bottom:20px}
.input-group label{display:block;margin-bottom:8px;color:#aaa;font-size:14px}
.input-group input{width:100%;padding:15px;border:2px solid #333;border-radius:10px;background:#0d0d1a;color:#fff;font-size:16px;transition:border-color .3s}
.input-group input:focus{outline:none;border-color:#4facfe}
.btn{width:100%;padding:15px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}
.btn.primary{background:linear-gradient(90deg,#4facfe,#00f2fe);color:#fff}
.btn.primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px rgba(79,172,254,.4)}
.btn.primary:active{transform:translateY(0)}
.hint{text-align:center;color:#666;font-size:14px;margin-top:20px}
.status{display:flex;align-items:center;gap:10px;margin-top:20px;padding:10px 20px;background:rgba(0,0,0,.3);border-radius:20px}
.status-dot{width:10px;height:10px;border-radius:50%;background:#ff4444;animation:blink 1s infinite}
.status.connected .status-dot{background:#00ff88;animation:none}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.5}}
#control-screen{padding:0;justify-content:flex-start}
.control-header{width:100%;padding:10px 15px;display:flex;justify-content:space-between;align-items:center;background:rgba(0,0,0,.5);flex-shrink:0}
.header-left{display:flex;align-items:center;gap:15px}
#peer-info{color:#4facfe;font-size:14px}
.latency{font-size:12px;color:#888}
.header-right{display:flex;gap:10px}
.icon-btn{width:36px;height:36px;border:none;border-radius:8px;background:rgba(255,255,255,.1);color:#fff;font-size:16px;cursor:pointer;transition:background .3s}
.icon-btn:hover{background:rgba(255,255,255,.2)}
.icon-btn.danger:hover{background:rgba(255,68,68,.3)}
#screen-container{flex:1;width:100%;position:relative;overflow:hidden;background:#000}
#remote-screen{width:100%;height:100%;display:block}
#touch-indicator{position:absolute;width:40px;height:40px;border-radius:50%;background:rgba(79,172,254,.5);pointer-events:none;display:none;transform:translate(-50%,-50%)}
.control-footer{width:100%;padding:10px 15px;background:rgba(0,0,0,.5);flex-shrink:0}
.control-buttons{display:flex;justify-content:center;gap:15px;margin-bottom:10px}
.control-btn{width:50px;height:50px;border:none;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:18px;cursor:pointer;transition:all .3s}
.control-btn:hover{background:rgba(79,172,254,.3);transform:scale(1.1)}
.control-btn:active{transform:scale(.95)}
.quick-keys{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.key-btn{padding:8px 15px;border:1px solid #444;border-radius:5px;background:rgba(255,255,255,.05);color:#fff;font-size:12px;cursor:pointer;transition:all .3s}
.key-btn:hover{background:rgba(79,172,254,.2);border-color:#4facfe}
.key-btn:active{background:rgba(79,172,254,.4)}
.panel{position:fixed;bottom:0;left:0;right:0;max-height:60vh;background:#1a1a2e;border-radius:20px 20px 0 0;overflow:hidden;animation:slideUp .3s;z-index:100}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.panel-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #333;font-weight:600}
.keyboard-content,.settings-content,.adb-content{padding:15px;max-height:calc(60vh - 60px);overflow-y:auto}
#text-input{width:100%;min-height:80px;padding:10px;border:1px solid #333;border-radius:8px;background:#0d0d1a;color:#fff;font-size:16px;resize:vertical;margin-bottom:15px}
.keyboard-row{display:flex;gap:10px;margin-bottom:10px}
.key-btn.modifier{flex:1}.key-btn.combo{flex:1}
.adb-status{margin-bottom:15px}
#adb-output{width:100%;min-height:60px;padding:10px;background:#0d0d1a;border-radius:8px;color:#4facfe;font-family:monospace;font-size:12px;margin-top:10px;overflow-x:auto;white-space:pre-wrap}
.adb-quick-cmds{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:15px}
.adb-btn{padding:12px;border:1px solid #333;border-radius:8px;background:rgba(79,172,254,.1);color:#fff;font-size:14px;cursor:pointer;transition:all .3s}
.adb-btn:hover{background:rgba(79,172,254,.2)}
.adb-input-cmd{display:flex;gap:10px}
.adb-input-cmd input{flex:1;padding:10px;border:1px solid #333;border-radius:8px;background:#0d0d1a;color:#fff}
.adb-input-cmd .btn{width:auto;padding:10px 20px}
.setting-item{display:flex;align-items:center;gap:15px;padding:10px 0;border-bottom:1px solid #333}
.setting-item label{flex:1;color:#aaa}
.setting-item input[type=range]{flex:2;-webkit-appearance:none;height:6px;background:#333;border-radius:3px}
.setting-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:#4facfe;border-radius:50%;cursor:pointer}
.setting-item input[type=checkbox]{width:20px;height:20px;cursor:pointer}
.mode-tabs{display:flex;gap:5px;background:#0d0d1a;padding:4px;border-radius:8px}.mode-tab{padding:8px 16px;border:none;border-radius:6px;background:transparent;color:#888;font-size:14px;cursor:pointer;transition:all .2s}.mode-tab.active{background:#4facfe;color:#fff}.mode-tab:hover:not(.active){color:#4facfe}
.view{flex:1;width:100%;display:none;flex-direction:column}.view.active{display:flex}
.phone-list{flex:1;padding:20px;overflow-y:auto}.phone-list-hint{text-align:center;color:#888;padding:40px}.phone-device-card{padding:15px;margin-bottom:10px;background:#0d0d1a;border-radius:10px;border:1px solid #333;cursor:pointer;transition:all .3s}.phone-device-card:hover{border-color:#4facfe;background:rgba(79,172,254,.05)}.phone-device-name{font-size:18px;color:#fff;margin-bottom:5px}.phone-device-ip{font-size:14px;color:#888}
.phone-stream{flex:1;display:flex;flex-direction:column}.phone-stream-header{padding:10px 15px;display:flex;justify-content:space-between;align-items:center;background:#0d0d1a}.phone-stream-container{flex:1;position:relative;overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center}.phone-stream-container img{max-width:100%;max-height:100%;object-fit:contain}
#phone-touch-indicator{position:absolute;width:30px;height:30px;border-radius:50%;background:rgba(0,242,254,.5);pointer-events:none;display:none;transform:translate(-50%,-50%)}
.phone-actions{padding:10px 15px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;background:#0d0d1a}.phone-action-btn{padding:10px 20px;border:1px solid #333;border-radius:8px;background:rgba(79,172,254,.1);color:#fff;font-size:14px;cursor:pointer;transition:all .2s}.phone-action-btn:hover{background:rgba(79,172,254,.2);border-color:#4facfe}
.btn.small{padding:8px 12px;font-size:12px;width:auto}

/* Tailscale status */
.ts-status{display:flex;align-items:center;gap:8px;padding:8px 16px;margin-top:15px;border-radius:20px;font-size:13px;transition:all .3s}
.ts-status.ts-online{background:rgba(0,255,136,.1);border:1px solid rgba(0,255,136,.3);color:#00ff88}
.ts-status.ts-offline{background:rgba(255,170,0,.08);border:1px solid rgba(255,170,0,.2);color:#ffaa00}
.ts-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ts-online .ts-dot{background:#00ff88;box-shadow:0 0 6px #00ff88}
.ts-offline .ts-dot{background:#ffaa00}
.ts-status a{color:#4facfe;text-decoration:underline}

@media(max-width:480px){.logo h1{font-size:24px}.logo-icon{font-size:48px}.adb-quick-cmds{grid-template-columns:repeat(2,1fr)}.quick-keys{gap:5px}.key-btn{padding:6px 10px;font-size:11px}.phone-actions{gap:5px}.phone-action-btn{padding:8px 12px;font-size:12px}}
