.gcp-wrap{--cyan:#4db5de;--cyan2:#73d2ef;--bg:#f7f8fa;--panel:#ffffff;--border:#dbe2e8;--text:#2d3748;--muted:#6b7280;max-width:1280px;margin:20px auto;padding:16px;background:var(--bg);border:1px solid var(--border);border-radius:18px;font-family:Arial,Helvetica,sans-serif;color:var(--text);box-sizing:border-box}
.gcp-wrap *{box-sizing:border-box}
.gcp-topbar{display:flex;gap:14px;align-items:center;margin-bottom:16px}
.gcp-main-connect{background:#fff;border:1px solid #cfd8e3;border-radius:10px;padding:12px 18px;font-size:15px;cursor:pointer;min-width:220px}
.gcp-status{flex:1;padding:12px 14px;background:#fff;border:1px solid #cfd8e3;border-radius:10px;color:var(--muted);font-size:14px}
.gcp-grid{display:grid;grid-template-columns:1.2fr .88fr;gap:18px;align-items:start}
.gcp-panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px}
.gcp-panel-title{font-size:16px;font-weight:600;margin-bottom:14px;color:#1f2937}
.gcp-controller-stage{display:flex;justify-content:center;align-items:center;min-height:520px;background:#fff;border-radius:12px;overflow:hidden}
.gcp-controller-stage svg{width:100%;max-width:740px;height:auto;display:block}
.gcp-btn-stack{display:flex;flex-direction:column;gap:12px}
.gcp-btn{border:none;border-radius:10px;padding:14px 16px;font-size:16px;color:#fff;cursor:pointer;text-align:center;font-weight:600}
.gcp-btn-blue{background:linear-gradient(180deg,#1780ff,#0b66da)}
.gcp-btn-green{background:linear-gradient(180deg,#11a774,#0d9567)}
.gcp-btn-gray{background:linear-gradient(180deg,#7b8798,#687384)}
.gcp-btn-red{background:linear-gradient(180deg,#de3a6b,#c62858)}
.gcp-joystick-wrap{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.gcp-stick-box{padding:10px;border:1px solid #e4e9ef;border-radius:12px;background:#fcfdff}
.gcp-stick-box canvas{width:100%;height:auto;display:block;background:#fff;border-radius:10px}
.gcp-stick-values{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;font-size:14px;color:#4b5563}
.gcp-stick-values strong{color:#111827}
.gcp-zoom-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.gcp-mode{background:#eef2f7;border:1px solid #d7e0ea;border-radius:8px;padding:8px 12px;cursor:pointer;color:#334155}
.gcp-mode.is-active{background:#2f3c52;color:#fff;border-color:#2f3c52}
.gcp-footer-note{margin-top:14px;font-size:13px;color:#6b7280;padding:4px 2px}
#gcp-controller-svg .outline{stroke:var(--cyan);stroke-width:5;fill:none;stroke-linecap:round;stroke-linejoin:round}
#gcp-controller-svg .thin{stroke-width:4}
#gcp-controller-svg .fill-light{fill:rgba(115,210,239,.09);stroke:var(--cyan);stroke-width:4}
#gcp-controller-svg .interactive{transition:fill .1s ease,stroke .1s ease,opacity .1s ease,transform .05s linear;transform-origin:center center}
#gcp-controller-svg .interactive.active{fill:rgba(77,181,222,.28)!important;stroke:#118ec4}
#gcp-controller-svg .face-symbol{stroke:var(--cyan);stroke-width:4;fill:none;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
#gcp-controller-svg .speaker-dot{fill:var(--cyan)}
#gcp-controller-svg .ps-dot{fill:none;stroke:var(--cyan);stroke-width:4}
.gcp-panel canvas{max-width:100%}
@media (max-width: 980px){.gcp-grid{grid-template-columns:1fr}.gcp-controller-stage{min-height:380px}.gcp-topbar{flex-direction:column;align-items:stretch}}
